@gaodefa/daocore 2026.5.29 → 2026.5.30

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 (1068) hide show
  1. package/dist/abort-DI3P6TIb.js +277 -0
  2. package/dist/abort.runtime-B6Z7lDEa.js +2 -0
  3. package/dist/abort.runtime.js +1 -1
  4. package/dist/account-inspect-BFz7X0TX.js +173 -0
  5. package/dist/accounts-BoYYrY7x.js +107 -0
  6. package/dist/accounts-Busq29zW.js +107 -0
  7. package/dist/accounts-CuvH2tuN.js +119 -0
  8. package/dist/accounts-DkIcqvf7.js +2 -0
  9. package/dist/acp-runtime-BA8lzXzf.js +26 -0
  10. package/dist/acp-spawn-DPz2aX3A.js +2 -0
  11. package/dist/acp-spawn-DvVCsWYV.js +1275 -0
  12. package/dist/acp-stateful-target-driver-DcC76aZW.js +89 -0
  13. package/dist/action-kill-D-dVisIX.js +33 -0
  14. package/dist/action-runtime-BEiqwxDD.js +469 -0
  15. package/dist/action-runtime-api-1LzcGjcX.js +2 -0
  16. package/dist/action-send-c3CnDuPg.js +39 -0
  17. package/dist/action-spawn-Dj4kwpWs.js +47 -0
  18. package/dist/actions-qLccmQBc.js +161 -0
  19. package/dist/actions.runtime-B5vYAgNi.js +5 -0
  20. package/dist/agent-command-D6Ds198G.js +1367 -0
  21. package/dist/agent-components.runtime-xquK0B3L.js +10 -0
  22. package/dist/agent-components.runtime.js +1 -1
  23. package/dist/agent-harness-runtime-Dq1fCBOM.js +180 -0
  24. package/dist/agent-harness-task-runtime-DvSEqFkD.js +140 -0
  25. package/dist/agent-lm5ZYOFy.js +3 -0
  26. package/dist/agent-runner-execution-Dbh2pDhQ.js +1713 -0
  27. package/dist/agent-runner-utils-Di3r2T1T.js +266 -0
  28. package/dist/agent-runner.runtime-BW90EcGW.js +3455 -0
  29. package/dist/agent-runner.runtime.js +1 -1
  30. package/dist/agent-runtime-BgIT5Ytc.js +229 -0
  31. package/dist/agent-via-gateway-DMMS8-hK.js +463 -0
  32. package/dist/agent-ylolD8-V.js +2 -0
  33. package/dist/api-BB4vXLtW.js +2 -0
  34. package/dist/api-CUhM3KNB.js +134 -0
  35. package/dist/api-CewRHSbT.js +6 -0
  36. package/dist/api-CfKjNJlW.js +2 -0
  37. package/dist/api-Rsnqui1u.js +3 -0
  38. package/dist/api-k7AvxwHr.js +639 -0
  39. package/dist/apply-DQ4TQNMA.js +54 -0
  40. package/dist/apply-S_75Py4Y.js +41 -0
  41. package/dist/approval-handler.runtime-Cthxrstu.js +130 -0
  42. package/dist/assistant-Cp9pGaBw.js +291 -0
  43. package/dist/attachment-normalize-5R0bLLOj.js +225 -0
  44. package/dist/attempt-execution-DuyyZYsU.js +558 -0
  45. package/dist/attempt-execution.runtime-DF2GPgNh.js +3 -0
  46. package/dist/attempt-execution.runtime.js +1 -1
  47. package/dist/attempt-execution.shared-CwdukA3t.js +38 -0
  48. package/dist/attempt.prompt-helpers-CUqKtIa5.js +475 -0
  49. package/dist/attempt.tool-run-context-BbN4_BYO.js +2094 -0
  50. package/dist/binding-routing-C6Ex2Blu.js +113 -0
  51. package/dist/binding-targets-BqREncSL.js +121 -0
  52. package/dist/bot-DGMEkaIJ.js +7894 -0
  53. package/dist/bot-deps-BltYjeMX.js +2 -0
  54. package/dist/bot-deps-XvGCor9f.js +747 -0
  55. package/dist/bot-message-context.runtime-kK-xvLV7.js +7 -0
  56. package/dist/bot-message-context.runtime.js +1 -1
  57. package/dist/bot-message-context.session.runtime-DpOIJUae.js +12 -0
  58. package/dist/bot-message-context.session.runtime.js +1 -1
  59. package/dist/bot-native-commands.delivery.runtime-D49p5Lc1.js +4 -0
  60. package/dist/bot-native-commands.delivery.runtime.js +1 -1
  61. package/dist/bot-native-commands.runtime-8XBdSpkQ.js +13 -0
  62. package/dist/bot-native-commands.runtime.js +1 -1
  63. package/dist/bridge-server-y_XGduPx.js +113 -0
  64. package/dist/browser-cli-B2jmmTT3.js +230 -0
  65. package/dist/browser-cli-actions-input-JQt5ZQcn.js +473 -0
  66. package/dist/browser-cli-actions-observe-CrfKh6AX.js +81 -0
  67. package/dist/browser-cli-debug-DQACWlvC.js +137 -0
  68. package/dist/browser-cli-inspect-DDnxx0Xw.js +104 -0
  69. package/dist/browser-cli-lEuOnZzs.js +2 -0
  70. package/dist/browser-cli-manage-DogmwtYt.js +443 -0
  71. package/dist/browser-cli-resize-BHuV71VZ.js +26 -0
  72. package/dist/browser-cli-shared-CidShgoF.js +50 -0
  73. package/dist/browser-cli-state-i8cCGbiQ.js +337 -0
  74. package/dist/browser-control-auth-CKfXdXWj.js +2 -0
  75. package/dist/browser-profiles-ATBTvUGh.js +2 -0
  76. package/dist/browser-runtime-KmCT6FuL.js +384 -0
  77. package/dist/build-DOOT6f62.js +257 -0
  78. package/dist/build-info.json +3 -3
  79. package/dist/bundled/boot-md/handler.js +2 -2
  80. package/dist/bundled/session-memory/handler.js +1 -1
  81. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  82. package/dist/capability-cli-DwvrwB-g.js +1782 -0
  83. package/dist/channel-B-wgK1bK.js +481 -0
  84. package/dist/channel-B1e_k1P0.js +867 -0
  85. package/dist/channel-BRDfa5tc.js +1777 -0
  86. package/dist/channel-BVEO1O4p.js +376 -0
  87. package/dist/channel-BYlO5l1d.js +508 -0
  88. package/dist/channel-Bl0sPoNx.js +653 -0
  89. package/dist/channel-C84xtDBy.js +1134 -0
  90. package/dist/channel-CLgKq4Ds.js +1556 -0
  91. package/dist/channel-CZT0qxLh.js +1249 -0
  92. package/dist/channel-CffBHWkb.js +955 -0
  93. package/dist/channel-D34ZJvVB.js +2126 -0
  94. package/dist/channel-DcdXLo_W.js +238 -0
  95. package/dist/channel-DnK5TrXV.js +362 -0
  96. package/dist/channel-Dzj4RHY2.js +740 -0
  97. package/dist/channel-OhZzLZCj.js +562 -0
  98. package/dist/channel-actions.runtime-Cdvhqc9s.js +265 -0
  99. package/dist/channel-actions.runtime.js +1 -1
  100. package/dist/channel-core-Dz9I_R4j.js +5 -0
  101. package/dist/channel-inbound-COGoV_aS.js +80 -0
  102. package/dist/channel-mP6HCIMr.js +1496 -0
  103. package/dist/channel-plugin-runtime-C0R46KeG.js +998 -0
  104. package/dist/channel-quGdgWel.js +808 -0
  105. package/dist/channel-runtime-FvPQoIF9.js +408 -0
  106. package/dist/channel.runtime-2vUz3gij.js +109 -0
  107. package/dist/channel.runtime-BZLDSNuQ.js +254 -0
  108. package/dist/channel.runtime-Bo5jO0Hj.js +4 -0
  109. package/dist/channel.runtime-CDgvrjM2.js +652 -0
  110. package/dist/channel.runtime-COf8SDFn.js +88 -0
  111. package/dist/channel.runtime-C_C1f8lu.js +733 -0
  112. package/dist/channel.runtime-CqPbsg8t.js +2528 -0
  113. package/dist/channel.runtime-DtV85Khx.js +1008 -0
  114. package/dist/channel.runtime-Spt1ukGW.js +21009 -0
  115. package/dist/channel.setup-Bc0LUQS1.js +1098 -0
  116. package/dist/channel.setup-ChTkj2hq.js +343 -0
  117. package/dist/channel.setup-CpMD9F8i.js +10 -0
  118. package/dist/chat-mUsjD5YN.js +2666 -0
  119. package/dist/chrome-u314zcbM.js +1503 -0
  120. package/dist/cli/run-main.js +5 -5
  121. package/dist/cli-CJMoqXrc.js +1341 -0
  122. package/dist/cli-compaction-qGYB7suI.js +347 -0
  123. package/dist/cli-metadata-BBJFpNU9.js +22 -0
  124. package/dist/cli-runner-C0kcts0I.js +540 -0
  125. package/dist/cli-runner-CTm8K6s8.js +2 -0
  126. package/dist/cli-runner.runtime-C8deL5FL.js +3 -0
  127. package/dist/cli-runner.runtime-DDAg1D0L.js +4 -0
  128. package/dist/cli-runner.runtime.js +1 -1
  129. package/dist/cli-startup-metadata.json +8 -8
  130. package/dist/client-CPxpgs4m.js +650 -0
  131. package/dist/client-adapter-CLlqOqfu.js +897 -0
  132. package/dist/client-factory-R7Rr2jwn.js +9 -0
  133. package/dist/command-auth-CkQP1buP.js +135 -0
  134. package/dist/command-handlers-CJEjFyMk.js +1609 -0
  135. package/dist/command-registry-BDgyOqDw.js +4 -0
  136. package/dist/command-registry-BVi5Jn1S.js +9 -0
  137. package/dist/command-registry-core-JCfsVRtz.js +110 -0
  138. package/dist/command-status.runtime-CM1JLzi6.js +90 -0
  139. package/dist/command-status.runtime.js +1 -1
  140. package/dist/commands-acp-C1-I78U6.js +74 -0
  141. package/dist/commands-compact.runtime-DOsNavwp.js +10 -0
  142. package/dist/commands-compact.runtime.js +1 -1
  143. package/dist/commands-handlers.runtime-BD1n2WGw.js +6154 -0
  144. package/dist/commands-handlers.runtime.js +1 -1
  145. package/dist/commands-status-DU_UTQz1.js +16 -0
  146. package/dist/commands-status-DejfTakp.js +3 -0
  147. package/dist/commands-status.runtime-DejfTakp.js +3 -0
  148. package/dist/commands-status.runtime.js +1 -1
  149. package/dist/commands-subagents-control.runtime-D7vo_2Y_.js +3 -0
  150. package/dist/commands-subagents-control.runtime-DGybTjJ6.js +2 -0
  151. package/dist/commands-subagents-control.runtime.js +1 -1
  152. package/dist/commands-system-prompt-BEBXAMea.js +2 -0
  153. package/dist/commands-system-prompt-gj3oQpQO.js +162 -0
  154. package/dist/commands.runtime-CgXX70IN.js +176 -0
  155. package/dist/commands.runtime.js +1 -1
  156. package/dist/commitments/runtime.js +1 -1
  157. package/dist/compact-C41XxMDt.js +480 -0
  158. package/dist/compact-DUVAF9EC.js +1141 -0
  159. package/dist/compact.runtime-COMRg6s3.js +12 -0
  160. package/dist/compact.runtime.js +1 -1
  161. package/dist/completion-cli-CmEYoB9a.js +315 -0
  162. package/dist/computer-use-BwJHu1QF.js +367 -0
  163. package/dist/config-ATBTvUGh.js +2 -0
  164. package/dist/config-DlNgjF8W.js +373 -0
  165. package/dist/config-mutations-tl_OqI6d.js +159 -0
  166. package/dist/context-engine-host-compat-BNPAIK9F.js +288 -0
  167. package/dist/context-engine-host-compat-C69CK7zS.js +2 -0
  168. package/dist/context-engine-lifecycle-iQ8f5a_-.js +1274 -0
  169. package/dist/control-auth-vVxyGKxY.js +114 -0
  170. package/dist/control-service-73nj79EW.js +145 -0
  171. package/dist/control-ui/assets/agents-DdWIz8Vk.js +1008 -0
  172. package/dist/control-ui/assets/channel-config-extras-C7ELhuDi.js +2 -0
  173. package/dist/control-ui/assets/channels-Bsoj-9BS.js +367 -0
  174. package/dist/control-ui/assets/cron-BRTEw1tT.js +1013 -0
  175. package/dist/control-ui/assets/debug-EKl_F8_L.js +97 -0
  176. package/dist/control-ui/assets/index-DSbSO7ys.js +7370 -0
  177. package/dist/control-ui/assets/instances-B1AoYwI5.js +57 -0
  178. package/dist/control-ui/assets/logs-BChOznzh.js +74 -0
  179. package/dist/control-ui/assets/nodes-5yebKh9k.js +436 -0
  180. package/dist/control-ui/assets/sessions-BlDYNThc.js +399 -0
  181. package/dist/control-ui/assets/skills-shared-CNFnf7KU.js +11 -0
  182. package/dist/control-ui/assets/skills-uxTDRmLx.js +314 -0
  183. package/dist/control-ui/index.html +1 -1
  184. package/dist/control-ui/sw.js +1 -1
  185. package/dist/conversation-binding-runtime-CmoTKcY1.js +4 -0
  186. package/dist/conversation-runtime-BxOHxuin.js +31 -0
  187. package/dist/core-D0Y2H55f.js +282 -0
  188. package/dist/core-api-BKlJUtDt.js +5 -0
  189. package/dist/core-api-_fiftUHn.js +2 -0
  190. package/dist/crestodian/crestodian.js +1 -1
  191. package/dist/crestodian/rescue-message.js +1 -1
  192. package/dist/crestodian-BJifoQiR.js +55 -0
  193. package/dist/daocore-tools-BMdF8RwK.js +11727 -0
  194. package/dist/delivery-e2ci_bcX.js +1002 -0
  195. package/dist/dialogue-BXayGhnz.js +37 -0
  196. package/dist/dir-fetch-tool-Cara5mZh.js +565 -0
  197. package/dist/dir-list-tool-CQ8Bo5Ez.js +100 -0
  198. package/dist/direct-dm-CPk6Qm9D.js +64 -0
  199. package/dist/directive-handling.fast-lane-BQ9aXqk8.js +68 -0
  200. package/dist/directive-handling.impl--a5AGurq.js +818 -0
  201. package/dist/directive-handling.impl-C4JqMwle.js +2 -0
  202. package/dist/directive-handling.model-selection-pyTYMIXn.js +122 -0
  203. package/dist/directive-handling.persist.runtime-B7vWT1r9.js +263 -0
  204. package/dist/directive-handling.persist.runtime.js +1 -1
  205. package/dist/dispatch-3Ru_eGq1.js +1640 -0
  206. package/dist/dispatch-acp-transcript.runtime-CYMP-5oE.js +40 -0
  207. package/dist/dispatch-acp-transcript.runtime.js +1 -1
  208. package/dist/dispatch-acp.runtime-BVCiklXk.js +18 -0
  209. package/dist/dispatch-acp.runtime.js +1 -1
  210. package/dist/doctor-B8mR3Sgr.js +2 -0
  211. package/dist/doctor-BJ6DuerV.js +6 -0
  212. package/dist/doctor-config-flow-BdOGs_zn.js +1741 -0
  213. package/dist/doctor-core-checks-CDf0stz-.js +2 -0
  214. package/dist/doctor-core-checks-Cpdnu2XI.js +573 -0
  215. package/dist/doctor-health-0qv_acBu.js +65 -0
  216. package/dist/doctor-health-contributions-Db1FQgFw.js +696 -0
  217. package/dist/doctor-lint-C1g4Llgl.js +94 -0
  218. package/dist/doctor-state-integrity-C8iXFLJ7.js +1231 -0
  219. package/dist/doctor-update-CsPu6p3d.js +58 -0
  220. package/dist/dynamic-tools-YQ0z0YKH.js +486 -0
  221. package/dist/embedded-backend-S0cahIZw.js +579 -0
  222. package/dist/embedded-gateway-stub.runtime-Cjw12ALm.js +12 -0
  223. package/dist/embedded-gateway-stub.runtime.js +1 -1
  224. package/dist/exec-approvals-ArHHjoE-.js +149 -0
  225. package/dist/extensionAPI.js +1 -1
  226. package/dist/extensions/active-memory/index.js +1 -1
  227. package/dist/extensions/admin-http-rpc/index.js +1 -1
  228. package/dist/extensions/browser/browser-bridge.js +1 -1
  229. package/dist/extensions/browser/browser-config.js +4 -4
  230. package/dist/extensions/browser/browser-control-auth.js +2 -2
  231. package/dist/extensions/browser/browser-doctor.js +2 -2
  232. package/dist/extensions/browser/browser-maintenance.js +1 -1
  233. package/dist/extensions/browser/browser-profiles.js +2 -2
  234. package/dist/extensions/browser/browser-runtime-api.js +11 -11
  235. package/dist/extensions/browser/cli-metadata.js +1 -1
  236. package/dist/extensions/browser/index.js +1 -1
  237. package/dist/extensions/browser/plugin-registration.js +1 -1
  238. package/dist/extensions/browser/register.runtime.js +4 -4
  239. package/dist/extensions/browser/runtime-api.js +13 -13
  240. package/dist/extensions/canvas/index.js +1 -1
  241. package/dist/extensions/clickclack/api.js +2 -2
  242. package/dist/extensions/clickclack/channel-plugin-api.js +1 -1
  243. package/dist/extensions/clickclack/runtime-api.js +2 -2
  244. package/dist/extensions/device-pair/api.js +1 -1
  245. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  246. package/dist/extensions/file-transfer/index.js +4 -4
  247. package/dist/extensions/imessage/api.js +2 -2
  248. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  249. package/dist/extensions/imessage/message-tool-api.d.ts +1 -1
  250. package/dist/extensions/imessage/runtime-api.js +3 -3
  251. package/dist/extensions/irc/api.js +2 -2
  252. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  253. package/dist/extensions/llm-task/index.js +1 -1
  254. package/dist/extensions/mattermost/api.js +1 -1
  255. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  256. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  257. package/dist/extensions/mattermost/policy-api.js +1 -1
  258. package/dist/extensions/mattermost/runtime-api.js +2 -2
  259. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  260. package/dist/extensions/memory-core/cli-metadata.js +1 -1
  261. package/dist/extensions/migrate-claude/apply.js +1 -1
  262. package/dist/extensions/migrate-claude/index.js +1 -1
  263. package/dist/extensions/migrate-claude/plan.js +1 -1
  264. package/dist/extensions/migrate-claude/provider.js +1 -1
  265. package/dist/extensions/migrate-claude/targets.js +1 -1
  266. package/dist/extensions/migrate-hermes/apply.js +1 -1
  267. package/dist/extensions/migrate-hermes/index.js +1 -1
  268. package/dist/extensions/migrate-hermes/model.js +1 -1
  269. package/dist/extensions/migrate-hermes/plan.js +1 -1
  270. package/dist/extensions/migrate-hermes/provider.js +1 -1
  271. package/dist/extensions/migrate-hermes/secrets.js +1 -1
  272. package/dist/extensions/migrate-hermes/targets.js +1 -1
  273. package/dist/extensions/policy/api.js +1 -1
  274. package/dist/extensions/policy/index.js +2 -2
  275. package/dist/extensions/signal/api.js +6 -6
  276. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  277. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  278. package/dist/extensions/signal/runtime-api.js +7 -7
  279. package/dist/extensions/skill-workshop/api.js +1 -1
  280. package/dist/extensions/skill-workshop/index.js +2 -2
  281. package/dist/extensions/telegram/account-inspect-api.js +1 -1
  282. package/dist/extensions/telegram/api.js +11 -11
  283. package/dist/extensions/telegram/channel-plugin-api.js +2 -2
  284. package/dist/extensions/telegram/contract-api.js +3 -3
  285. package/dist/extensions/telegram/runtime-api.js +7 -7
  286. package/dist/extensions/telegram/security-audit-contract-api.js +1 -1
  287. package/dist/extensions/telegram/setup-plugin-api.js +1 -1
  288. package/dist/extensions/telegram/test-api.js +2 -2
  289. package/dist/extensions/webhooks/api.js +1 -1
  290. package/dist/extensions/webhooks/index.js +1 -1
  291. package/dist/extensions/xai/index.js +4 -4
  292. package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
  293. package/dist/extensions/xai/speech-provider.js +1 -1
  294. package/dist/extensions/xai/test-api.js +1 -1
  295. package/dist/extensions/xai/tts.js +1 -1
  296. package/dist/extensions/xai/web-search.js +1 -1
  297. package/dist/extensions/xai/xai-oauth.js +1 -1
  298. package/dist/file-fetch-tool-DQpAtjX4.js +124 -0
  299. package/dist/file-write-tool-CkB0oYwe.js +127 -0
  300. package/dist/format-DUJUpMFQ.js +1145 -0
  301. package/dist/gateway-cli-CQo_E4Ka.js +435 -0
  302. package/dist/gateway-method-runtime-1QPgVJH7.js +21 -0
  303. package/dist/get-reply-DfUcsC-O.js +4689 -0
  304. package/dist/get-reply-from-config.runtime-C95MG73O.js +2 -0
  305. package/dist/get-reply-from-config.runtime.js +1 -1
  306. package/dist/graph-users-DPJe0fPs.js +1419 -0
  307. package/dist/group-access-DefaNJ6L.js +112 -0
  308. package/dist/handle-action.guild-admin-C1sy1kGJ.js +288 -0
  309. package/dist/harness-BgPRdmNK.js +61 -0
  310. package/dist/health-DFR9A1YV.js +4 -0
  311. package/dist/heartbeat-runner-BiYVPs25.js +5 -0
  312. package/dist/heartbeat-runner.runtime-Bmaq8WUA.js +4 -0
  313. package/dist/heartbeat-runner.runtime.js +1 -1
  314. package/dist/hooks-CNJDuJUm.js +534 -0
  315. package/dist/inbound-direct-dm-runtime-DFt58p71.js +2 -0
  316. package/dist/inbound-reply-dispatch-kgSDM8ax.js +148 -0
  317. package/dist/index.js +1 -1
  318. package/dist/init-B0zO_U4r.js +59 -0
  319. package/dist/inline-buttons-B6zgQW3J.js +40 -0
  320. package/dist/internal-events-C3Q5t6hg.js +90 -0
  321. package/dist/isolated-agent-CaSU5GCJ.js +2 -0
  322. package/dist/isolated-agent-CnsD2TmP.js +1118 -0
  323. package/dist/lifecycle-i3WZDaIn.js +571 -0
  324. package/dist/list.probe-g0rUiVXW.js +449 -0
  325. package/dist/list.status-command-DG3PrmeO.js +789 -0
  326. package/dist/llm-slug-generator-CHlf69FU.js +78 -0
  327. package/dist/llm-slug-generator.js +1 -1
  328. package/dist/local-dispatch.runtime-CDeHUp_A.js +9 -0
  329. package/dist/local-dispatch.runtime.js +1 -1
  330. package/dist/manager.runtime-BlLMPUTq.js +2714 -0
  331. package/dist/manager.runtime.js +1 -1
  332. package/dist/markdown-to-line-r_mBHMdy.js +811 -0
  333. package/dist/mcp-http-C5UPIJGR.js +555 -0
  334. package/dist/mcp-http-CTy9gpfA.js +2 -0
  335. package/dist/media-understanding-provider-BT6TOuVa.js +339 -0
  336. package/dist/message-actions-BdcjjwFt.js +145 -0
  337. package/dist/message-handler-B29Tj2p2.js +1715 -0
  338. package/dist/message-handler-BhHb1FHI.js +384 -0
  339. package/dist/message-handler.preflight-ouZ_-3o8.js +1125 -0
  340. package/dist/message-handler.process-CrYiBx_F.js +1484 -0
  341. package/dist/model-CLbtocQX.js +74 -0
  342. package/dist/model-selection-BG_vU9Kl.js +272 -0
  343. package/dist/models-4KERn3ya.js +104 -0
  344. package/dist/models-BCa-ipxi.js +2 -0
  345. package/dist/models-cli-DtpGXEsf.js +256 -0
  346. package/dist/monitor-B-egsvmI.js +1657 -0
  347. package/dist/monitor-BJX9Yv7k.js +2 -0
  348. package/dist/monitor-BPrIy3pV.js +715 -0
  349. package/dist/monitor-BWknZZ7N.js +4377 -0
  350. package/dist/monitor-C3y_PtI1.js +60 -0
  351. package/dist/monitor-DCzfdqE4.js +1370 -0
  352. package/dist/monitor-P24epSwE.js +2788 -0
  353. package/dist/monitor-auth-CEG_xldE.js +179 -0
  354. package/dist/monitor-jEePJbbS.js +834 -0
  355. package/dist/monitor-polling.runtime-BzlHK11u.js +883 -0
  356. package/dist/monitor-polling.runtime.js +1 -1
  357. package/dist/monitor-webhook.runtime-vFEhk_Zj.js +387 -0
  358. package/dist/monitor-webhook.runtime.js +1 -1
  359. package/dist/monitor.account-BUIfgWXg.js +5233 -0
  360. package/dist/monitor.runtime-Cp7W4fhb.js +2 -0
  361. package/dist/monitor.runtime.js +1 -1
  362. package/dist/monitor.webhook-DzrbeR4T.js +180 -0
  363. package/dist/node-cli-sessions-CLbI14UA.js +1228 -0
  364. package/dist/openai-http-BM9BIA_g.js +824 -0
  365. package/dist/openresponses-http-CNoW9kk8.js +1173 -0
  366. package/dist/operations-DT4bsxV6.js +805 -0
  367. package/dist/outbound-adapter-CZRUOgY0.js +543 -0
  368. package/dist/outbound-session-route-DneMsGNx.js +45 -0
  369. package/dist/outbound.runtime-CHuoKJJI.js +2 -0
  370. package/dist/outbound.runtime.js +1 -1
  371. package/dist/pi-embedded-1-rsueO_.js +3796 -0
  372. package/dist/pi-embedded-BRfDncVO.js +4 -0
  373. package/dist/pi-embedded.runtime-DEYoa6bW.js +4 -0
  374. package/dist/pi-embedded.runtime.js +1 -1
  375. package/dist/pi-tools-C0P3NgP5.js +2413 -0
  376. package/dist/plan-BQUkjBMY.js +81 -0
  377. package/dist/plan-CRO9_2_k.js +112 -0
  378. package/dist/plugin-BJCmWhnh.js +12396 -0
  379. package/dist/plugin-app-cache-key-CXAg0F7A.js +46 -0
  380. package/dist/plugin-enabled-D93Z9LSo.js +233 -0
  381. package/dist/plugin-registration-BBrTcZnf.js +88 -0
  382. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  383. package/dist/plugin-sdk/acp-runtime-backend.js +1 -1
  384. package/dist/plugin-sdk/acp-runtime.js +2 -2
  385. package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
  386. package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
  387. package/dist/plugin-sdk/agent-harness.js +7 -7
  388. package/dist/plugin-sdk/agent-runtime.js +2 -2
  389. package/dist/plugin-sdk/channel-core.js +2 -2
  390. package/dist/plugin-sdk/channel-inbound.js +2 -2
  391. package/dist/plugin-sdk/channel-test-helpers.js +1 -1
  392. package/dist/plugin-sdk/command-auth.js +1 -1
  393. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  394. package/dist/plugin-sdk/compat.js +1 -1
  395. package/dist/plugin-sdk/conversation-binding-runtime.js +2 -2
  396. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  397. package/dist/plugin-sdk/core.js +2 -2
  398. package/dist/plugin-sdk/direct-dm.js +1 -1
  399. package/dist/plugin-sdk/gateway-method-runtime.js +1 -1
  400. package/dist/plugin-sdk/health.js +2 -2
  401. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  402. package/dist/plugin-sdk/index.js +1 -1
  403. package/dist/plugin-sdk/mattermost.js +1 -1
  404. package/dist/plugin-sdk/plugin-test-contracts.js +2 -2
  405. package/dist/plugin-sdk/provider-test-contracts.js +4 -4
  406. package/dist/plugin-sdk/reply-runtime.js +4 -4
  407. package/dist/plugin-sdk/testing.js +2 -2
  408. package/dist/plugin-sdk/zalouser.js +1 -1
  409. package/dist/plugin-service-DnZEPBEA.js +1229 -0
  410. package/dist/plugins/runtime/index.js +4 -4
  411. package/dist/policy-CMv5QMPG.js +138 -0
  412. package/dist/policy-CeoP4t9J.js +680 -0
  413. package/dist/prepare.runtime-DZ55JiTt.js +732 -0
  414. package/dist/prepare.runtime.js +1 -1
  415. package/dist/preview-warnings-O08PZRxu.js +392 -0
  416. package/dist/probe-C6w3bP8X.js +682 -0
  417. package/dist/probe-Cs1_X1NA.js +47 -0
  418. package/dist/probe-Cuee_jyM.js +2204 -0
  419. package/dist/probe-DZxCnDzn.js +2 -0
  420. package/dist/program-C2dT8VHB.js +131 -0
  421. package/dist/provider-C2_vSzYh.js +32 -0
  422. package/dist/provider-DSfTDQbj.js +152 -0
  423. package/dist/provider-U8hrm9h-.js +32 -0
  424. package/dist/provider-_v910H8y.js +8735 -0
  425. package/dist/provider-dispatcher-C3kmmIEC.js +22 -0
  426. package/dist/provider-dispatcher.runtime.js +1 -1
  427. package/dist/provider-session.runtime-Mg0fx5hH.js +9 -0
  428. package/dist/provider-session.runtime.js +1 -1
  429. package/dist/provider.runtime-pSTXuHrq.js +2 -0
  430. package/dist/provider.runtime.js +1 -1
  431. package/dist/public-surface-loader-09t4TTue.js +114 -0
  432. package/dist/pw-ai-DjNqHV3_.js +3029 -0
  433. package/dist/pw-role-snapshot-DoGefdv7.js +333 -0
  434. package/dist/reaction-level-C8Mqxizo.js +19 -0
  435. package/dist/reaction-runtime-api-DOP6xOsm.js +116 -0
  436. package/dist/realtime-transcription-provider-BTGEXXna.js +205 -0
  437. package/dist/register-CbZPpqI3.js +2178 -0
  438. package/dist/register.agent-DrBFuPKh.js +156 -0
  439. package/dist/register.crestodian-DwTbmaK8.js +24 -0
  440. package/dist/register.maintenance-BIeoYBub.js +83 -0
  441. package/dist/register.runtime-B5V9_Dwz.js +54 -0
  442. package/dist/register.subclis-CJE9ISZY.js +31 -0
  443. package/dist/register.subclis-YQsKas8N.js +3 -0
  444. package/dist/register.subclis-core-CjwdGeGU.js +273 -0
  445. package/dist/repair-sequencing-C0jrL5pw.js +640 -0
  446. package/dist/reply-delivery-B28mTIpb.js +196 -0
  447. package/dist/reply-runtime-BqQX7HHw.js +11 -0
  448. package/dist/reply.runtime-C95MG73O.js +2 -0
  449. package/dist/reply.runtime.js +1 -1
  450. package/dist/request-BqoMvXxH.js +54 -0
  451. package/dist/resolve-allowlist-hbKKd_kq.js +220 -0
  452. package/dist/result-fallback-classifier-BrORPoxj.js +79 -0
  453. package/dist/route-HHRgSzVy.js +469 -0
  454. package/dist/route-resolution-C7bafjVc.js +274 -0
  455. package/dist/routes-86XGeo7a.js +2 -0
  456. package/dist/routes-BhVGr9ie.js +3602 -0
  457. package/dist/run-Bb5QP5JV.js +1162 -0
  458. package/dist/run-attempt-CLi0wV7j.js +7704 -0
  459. package/dist/run-command-Be6GAxiW.js +2 -0
  460. package/dist/run-command-Ds4hr3iU.js +23 -0
  461. package/dist/run-embedded.runtime-wX9ORojX.js +4 -0
  462. package/dist/run-embedded.runtime.js +1 -1
  463. package/dist/run-execution-cli.runtime-BmNZVB2N.js +4 -0
  464. package/dist/run-execution-cli.runtime.js +1 -1
  465. package/dist/run-executor.runtime.js +1 -1
  466. package/dist/run-subagent-registry.runtime-Uq5sjftu.js +2 -0
  467. package/dist/run-subagent-registry.runtime.js +1 -1
  468. package/dist/runtime-BktLQ75j.js +1287 -0
  469. package/dist/runtime-C9XdR62_.js +438 -0
  470. package/dist/runtime-CTvWDPx9.js +6179 -0
  471. package/dist/runtime-api-BojB3MUw.js +21 -0
  472. package/dist/runtime-api-C92MlAwp.js +13 -0
  473. package/dist/runtime-api-CFNZE9Xt.js +13 -0
  474. package/dist/runtime-api-Cimpgm5_.js +3 -0
  475. package/dist/runtime-api-D8qG_lUm.js +17 -0
  476. package/dist/runtime-api-DMDMnQEG.js +4 -0
  477. package/dist/runtime-api-DupQdIlE.js +24 -0
  478. package/dist/runtime-api.actions-B8i3elqu.js +3 -0
  479. package/dist/runtime-api.monitor-BntFzf_M.js +6 -0
  480. package/dist/runtime-api.send-CPlmi1jc.js +4 -0
  481. package/dist/runtime-api.threads-D-H_r_Nl.js +2 -0
  482. package/dist/runtime-channel-BGhTxnXZ.js +150 -0
  483. package/dist/runtime-channel-CPFxNapZ.js +2 -0
  484. package/dist/runtime-embedded-pi.runtime-BjnMTurB.js +2 -0
  485. package/dist/runtime-embedded-pi.runtime.js +1 -1
  486. package/dist/sanitize-outbound-BMUv1NeS.js +127 -0
  487. package/dist/sdk-setup-tools-Do3DkQi_.js +8 -0
  488. package/dist/secrets-B8YVPHhk.js +113 -0
  489. package/dist/security-audit-7Gg_nL4o.js +122 -0
  490. package/dist/security-audit-Bk3CREj-.js +118 -0
  491. package/dist/security-audit.runtime-BmSJrdeq.js +2 -0
  492. package/dist/security-audit.runtime.js +1 -1
  493. package/dist/selection-BFGde9-_.js +3 -0
  494. package/dist/selection-DrLFlbgG.js +16157 -0
  495. package/dist/send-4dLa-BQo.js +1631 -0
  496. package/dist/send-CV6gCwYP.js +192 -0
  497. package/dist/send-aGiK3Efu.js +143 -0
  498. package/dist/send-dB3CehAN.js +2 -0
  499. package/dist/send.components-BcG9BlkC.js +2 -0
  500. package/dist/send.components-rLjDlfYU.js +500 -0
  501. package/dist/send.runtime-D20k2MSr.js +2 -0
  502. package/dist/send.runtime.js +1 -1
  503. package/dist/server-BTRx_U1s.js +73 -0
  504. package/dist/server-CY0ymhBg.js +24 -0
  505. package/dist/server-close.runtime.js +1 -1
  506. package/dist/server-context-BxGT8wbK.js +955 -0
  507. package/dist/server-context-DYlbhAaT.js +2 -0
  508. package/dist/server-cron-BB_15lcP.js +2 -0
  509. package/dist/server-cron-CfyJX_a4.js +2989 -0
  510. package/dist/server-methods-Ck2ab6TC.js +16494 -0
  511. package/dist/server-node-events-BdRizF-5.js +596 -0
  512. package/dist/server-plugin-bootstrap-CPUr8NFE.js +70 -0
  513. package/dist/server-plugins-__5AxjzH.js +432 -0
  514. package/dist/server-reload-handlers-BMl9Fx9b.js +714 -0
  515. package/dist/server-restart-sentinel-D11M_ZsH.js +747 -0
  516. package/dist/server-restart-sentinel-DGptQ27c.js +2 -0
  517. package/dist/server-runtime-services-BwtLs-8I.js +2 -0
  518. package/dist/server-runtime-services-aJydixRu.js +267 -0
  519. package/dist/server-startup-plugins-m_P3gY4m.js +113 -0
  520. package/dist/server-startup-post-attach-DuXQ1AXL.js +716 -0
  521. package/dist/server-ws-runtime-mXmxB1W8.js +349 -0
  522. package/dist/server.impl-fuV8aKSP.js +2586 -0
  523. package/dist/service-a8cTFka4.js +1446 -0
  524. package/dist/session-binding-BIycxo9u.js +2 -0
  525. package/dist/session-binding-xHwQr9vM.js +219 -0
  526. package/dist/session-kill-http-DiUZhcoN.js +121 -0
  527. package/dist/session-reset-service-DkepDoob.js +625 -0
  528. package/dist/session-route-Ba5u7ecb.js +93 -0
  529. package/dist/session-status.runtime-Cb1X69Rl.js +2 -0
  530. package/dist/session-status.runtime.js +1 -1
  531. package/dist/session-subagent-reactivation.runtime-rbqmto4G.js +2 -0
  532. package/dist/session-subagent-reactivation.runtime.js +1 -1
  533. package/dist/session-tab-registry-DSKOoJta.js +521 -0
  534. package/dist/sessions-history-http-CWP88I_C.js +430 -0
  535. package/dist/sessions.runtime-1q1OwLn3.js +2 -0
  536. package/dist/sessions.runtime.js +1 -1
  537. package/dist/setup-api-DtrOOYeP.js +29 -0
  538. package/dist/setup-core-DMrJS6LP.js +174 -0
  539. package/dist/setup-surface-BFPNu1qA.js +405 -0
  540. package/dist/setup-surface-CedShqhO.js +288 -0
  541. package/dist/setup-surface-DLOBH1Vf.js +320 -0
  542. package/dist/setup-surface-MhCeEWSj.js +221 -0
  543. package/dist/shared-DamL-e8D.js +121 -0
  544. package/dist/shared-client-B48JoAsz.js +2 -0
  545. package/dist/shared-client-BoSiDnUo.js +629 -0
  546. package/dist/side-question-DQoQ_ETb.js +683 -0
  547. package/dist/skill-tool-dispatch.runtime-CWLloYA8.js +143 -0
  548. package/dist/skill-tool-dispatch.runtime.js +1 -1
  549. package/dist/slash-state-DrrWJQfv.js +2166 -0
  550. package/dist/speech-provider-8Hx1uw41.js +184 -0
  551. package/dist/src-BbUYOPwU.js +4256 -0
  552. package/dist/startup-context-opAJAamX.js +313 -0
  553. package/dist/status-subagents.runtime-DSo7ZK_Z.js +18 -0
  554. package/dist/status-subagents.runtime.js +1 -1
  555. package/dist/status-text-AyPuDzrO.js +296 -0
  556. package/dist/sticker-cache-91Tp8mLP.js +206 -0
  557. package/dist/sticker-vision.runtime-DjleFXi5.js +17 -0
  558. package/dist/sticker-vision.runtime.js +1 -1
  559. package/dist/subagent-announce-delivery-DS_2W9oZ.js +958 -0
  560. package/dist/subagent-announce-hatA_PZ2.js +354 -0
  561. package/dist/subagent-control-IyFIvc7T.js +508 -0
  562. package/dist/subagent-hooks-BCj5eB0Z.js +2 -0
  563. package/dist/subagent-hooks-BWjTBkox.js +146 -0
  564. package/dist/subagent-hooks-CdGLK9_3.js +230 -0
  565. package/dist/subagent-hooks-EH0tBkw9.js +2 -0
  566. package/dist/subagent-hooks-api-BhYaXQJV.js +23 -0
  567. package/dist/subagent-hooks-api-uGsV8Xn5.js +22 -0
  568. package/dist/subagent-hooks-api-wfJFKIPx.js +23 -0
  569. package/dist/subagent-hooks-l8Xd94dt.js +2 -0
  570. package/dist/subagent-hooks-m2eHUO_d.js +116 -0
  571. package/dist/subagent-orphan-recovery-Bq9zvX3L.js +352 -0
  572. package/dist/subagent-registry-Bcb3zy6b.js +3 -0
  573. package/dist/subagent-registry-CoZNTFx-.js +2351 -0
  574. package/dist/subagent-registry.runtime.js +1 -1
  575. package/dist/subagent-session-cleanup--00EjDLe.js +525 -0
  576. package/dist/subagent-spawn-ClJJkz3D.js +1164 -0
  577. package/dist/target-id-BsZLiF3x.js +107 -0
  578. package/dist/targets-CQMe4AZP.js +44 -0
  579. package/dist/targets-SmL1AU-H.js +19 -0
  580. package/dist/targets-Y-roiA47.js +19 -0
  581. package/dist/task-registry-control.runtime.js +1 -1
  582. package/dist/telegram/token.js +1 -1
  583. package/dist/testing-B5hNJDuF.js +267 -0
  584. package/dist/thread-bindings-BD3eE0kK.js +232 -0
  585. package/dist/thread-bindings-C9NNiv8K.js +571 -0
  586. package/dist/thread-bindings-Dl4PN1vZ.js +228 -0
  587. package/dist/thread-bindings-uK1LLAwy.js +8 -0
  588. package/dist/thread-bindings.discord-api-BHNEUbnk.js +187 -0
  589. package/dist/thread-bindings.manager-B0LXiH3F.js +2 -0
  590. package/dist/thread-bindings.manager-BTlH4XMG.js +536 -0
  591. package/dist/thread-lifecycle-DG8uyPHd.js +1614 -0
  592. package/dist/token-BbGCANnE.js +134 -0
  593. package/dist/tool-actions.runtime-oUUrD8HB.js +534 -0
  594. package/dist/tool-actions.runtime.js +1 -1
  595. package/dist/tool-bqg-_vYv.js +139 -0
  596. package/dist/tool-resolution-CSZsa3kP.js +149 -0
  597. package/dist/tools-effective-inventory-0CqFp-vq.js +204 -0
  598. package/dist/tools-invoke-http-DhYHY0Yh.js +67 -0
  599. package/dist/tools-invoke-shared-CbVJJUj7.js +200 -0
  600. package/dist/tts-C2qD-ad6.js +66 -0
  601. package/dist/tui-CzGY254f.js +4709 -0
  602. package/dist/tui-backend-fzoeoSN0.js +256 -0
  603. package/dist/tui-cli-B2RWb2gM.js +37 -0
  604. package/dist/tui-dgS8hdXU.js +2 -0
  605. package/dist/update-cli-BmiBDf3c.js +3664 -0
  606. package/dist/update-runner-CM7QVX6u.js +2379 -0
  607. package/dist/vision-tools-BzoBZnIc.js +1409 -0
  608. package/dist/web-search-DmfOd66S.js +62 -0
  609. package/dist/web-search-provider.runtime-3C5-pODD.js +328 -0
  610. package/dist/web-search-provider.runtime-Doh-Z9We.js +2 -0
  611. package/dist/web-search-provider.runtime.js +1 -1
  612. package/dist/xai-oauth-BLvQ43hx.js +479 -0
  613. package/dist/xai-user-agent-BdMQ_0_O.js +32 -0
  614. package/package.json +1 -1
  615. package/dist/abort-DeEb_wKd.js +0 -277
  616. package/dist/abort.runtime-CoYXQGPK.js +0 -2
  617. package/dist/account-inspect-D_06-CYS.js +0 -173
  618. package/dist/accounts-BCTqtj4Y.js +0 -107
  619. package/dist/accounts-BudLl8P2.js +0 -107
  620. package/dist/accounts-CUReBDA0.js +0 -2
  621. package/dist/accounts-PCioSzzr.js +0 -119
  622. package/dist/acp-runtime-B2t9_BHD.js +0 -26
  623. package/dist/acp-spawn-0x4Iiu1o.js +0 -2
  624. package/dist/acp-spawn-B2Ghe0jJ.js +0 -1275
  625. package/dist/acp-stateful-target-driver-C4VgcSyz.js +0 -89
  626. package/dist/action-kill-ClYsXEz7.js +0 -33
  627. package/dist/action-runtime-DrLPkNvU.js +0 -469
  628. package/dist/action-runtime-api-BqSflr9q.js +0 -2
  629. package/dist/action-send-CIy9cziD.js +0 -39
  630. package/dist/action-spawn-BjV6lFnX.js +0 -47
  631. package/dist/actions-D-QH7wq5.js +0 -161
  632. package/dist/actions.runtime-hzDtXQGU.js +0 -5
  633. package/dist/agent-Bb1DTBgv.js +0 -3
  634. package/dist/agent-Cnqj258q.js +0 -2
  635. package/dist/agent-command-BRx6ZNgJ.js +0 -1367
  636. package/dist/agent-components.runtime-D-g6xXJ0.js +0 -10
  637. package/dist/agent-harness-runtime-dKUQFuOc.js +0 -180
  638. package/dist/agent-harness-task-runtime-v2crUm3i.js +0 -140
  639. package/dist/agent-runner-execution-AOzdxvWR.js +0 -1713
  640. package/dist/agent-runner-utils-Byv50B4Z.js +0 -266
  641. package/dist/agent-runner.runtime-hhgRE0Z-.js +0 -3455
  642. package/dist/agent-runtime-BHmh3i0o.js +0 -229
  643. package/dist/agent-via-gateway-DnCqaK4a.js +0 -463
  644. package/dist/api-Bzyb8sFU.js +0 -3
  645. package/dist/api-CIEDFXZs.js +0 -2
  646. package/dist/api-D_dTQAu8.js +0 -2
  647. package/dist/api-DilBjZ9Q.js +0 -6
  648. package/dist/api-E5zoQMmh.js +0 -134
  649. package/dist/api-OJZug8gQ.js +0 -639
  650. package/dist/apply-C0eV5T0O.js +0 -41
  651. package/dist/apply-alsYvxLE.js +0 -54
  652. package/dist/approval-handler.runtime-C6jqZXSN.js +0 -130
  653. package/dist/assistant-DDXnAAB5.js +0 -291
  654. package/dist/attachment-normalize-Cv-_4DWU.js +0 -225
  655. package/dist/attempt-execution-DECEU59r.js +0 -558
  656. package/dist/attempt-execution.runtime-kasMxuER.js +0 -3
  657. package/dist/attempt-execution.shared-ClUxk52p.js +0 -38
  658. package/dist/attempt.prompt-helpers-Bxlv9VSu.js +0 -475
  659. package/dist/attempt.tool-run-context-CplQWX6g.js +0 -2094
  660. package/dist/binding-routing-0Obpp-Ij.js +0 -113
  661. package/dist/binding-targets-CZHQaZL4.js +0 -121
  662. package/dist/bot-BPbQ0840.js +0 -7894
  663. package/dist/bot-deps-Cs1M9USs.js +0 -2
  664. package/dist/bot-deps-xAcaOtTZ.js +0 -747
  665. package/dist/bot-message-context.runtime-Bji78Cbn.js +0 -7
  666. package/dist/bot-message-context.session.runtime-C3dyOIYH.js +0 -12
  667. package/dist/bot-native-commands.delivery.runtime-WshH99fy.js +0 -4
  668. package/dist/bot-native-commands.runtime-C1L364gU.js +0 -13
  669. package/dist/bridge-server-DPlM8_Lk.js +0 -113
  670. package/dist/browser-cli-DFNQE98N.js +0 -230
  671. package/dist/browser-cli-Drb5E5--.js +0 -2
  672. package/dist/browser-cli-actions-input-Dx-1OXmE.js +0 -473
  673. package/dist/browser-cli-actions-observe-BMDfE7xU.js +0 -81
  674. package/dist/browser-cli-debug-nu7Ih09g.js +0 -137
  675. package/dist/browser-cli-inspect-D5X2wohg.js +0 -104
  676. package/dist/browser-cli-manage-DkzYwph4.js +0 -443
  677. package/dist/browser-cli-resize-B30Avedl.js +0 -26
  678. package/dist/browser-cli-shared-cMgQoQzF.js +0 -50
  679. package/dist/browser-cli-state-CQLDvDy7.js +0 -337
  680. package/dist/browser-control-auth-D7ArmHUt.js +0 -2
  681. package/dist/browser-profiles-B39SIZNb.js +0 -2
  682. package/dist/browser-runtime-DUbSAOOS.js +0 -384
  683. package/dist/build-D25KqC92.js +0 -257
  684. package/dist/capability-cli-CuyXrlAB.js +0 -1782
  685. package/dist/channel-0N3YGMGg.js +0 -1496
  686. package/dist/channel-1UyKoLyp.js +0 -481
  687. package/dist/channel-BG87pSEW.js +0 -740
  688. package/dist/channel-BPGSaZW7.js +0 -1249
  689. package/dist/channel-BQMPh1J_.js +0 -376
  690. package/dist/channel-Bd_8V6zn.js +0 -1134
  691. package/dist/channel-BtBjh_ij.js +0 -362
  692. package/dist/channel-CpFBlVH6.js +0 -562
  693. package/dist/channel-CwuTrIrF.js +0 -508
  694. package/dist/channel-Cxl4sJA-.js +0 -1777
  695. package/dist/channel-D-VfU4Z2.js +0 -2126
  696. package/dist/channel-D9q8aYrN.js +0 -867
  697. package/dist/channel-DKSvVvZh.js +0 -238
  698. package/dist/channel-DvoFfWLx.js +0 -808
  699. package/dist/channel-GktTcGHm.js +0 -955
  700. package/dist/channel-actions.runtime-CKcRA0GW.js +0 -265
  701. package/dist/channel-core-nm8s1qFZ.js +0 -5
  702. package/dist/channel-d3t2ESlE.js +0 -653
  703. package/dist/channel-inbound-DKz40dq-.js +0 -80
  704. package/dist/channel-plugin-runtime-DKIGZWfW.js +0 -998
  705. package/dist/channel-runtime-Bh8_GY12.js +0 -408
  706. package/dist/channel-yQ8jCOb9.js +0 -1556
  707. package/dist/channel.runtime-BG4mM5cQ.js +0 -652
  708. package/dist/channel.runtime-BS6PyFFa.js +0 -1008
  709. package/dist/channel.runtime-CE_xECqN.js +0 -88
  710. package/dist/channel.runtime-Cd1Sw8U4.js +0 -254
  711. package/dist/channel.runtime-DIq3XOEe.js +0 -733
  712. package/dist/channel.runtime-Dy1cx35I.js +0 -21009
  713. package/dist/channel.runtime-NyIMjLnP.js +0 -109
  714. package/dist/channel.runtime-Zx5mfE2V.js +0 -4
  715. package/dist/channel.runtime-rJRibGfN.js +0 -2528
  716. package/dist/channel.setup--4ACadmF.js +0 -10
  717. package/dist/channel.setup-DzwqIlo3.js +0 -1098
  718. package/dist/channel.setup-FKYSJwXR.js +0 -343
  719. package/dist/chat-CKxSm7r1.js +0 -2666
  720. package/dist/chrome-rMubJwRG.js +0 -1503
  721. package/dist/cli-CbTod55I.js +0 -1341
  722. package/dist/cli-compaction-BbHgjJyW.js +0 -347
  723. package/dist/cli-metadata-DkOWLC_p.js +0 -22
  724. package/dist/cli-runner-Cwzv_RKf.js +0 -540
  725. package/dist/cli-runner-DdnUsgPl.js +0 -2
  726. package/dist/cli-runner.runtime-BlrSgbEW.js +0 -3
  727. package/dist/cli-runner.runtime-D8kVfvFH.js +0 -4
  728. package/dist/client-ClvxsWgL.js +0 -650
  729. package/dist/client-adapter-CsrIIjK1.js +0 -897
  730. package/dist/client-factory-DAYClhwm.js +0 -9
  731. package/dist/command-auth-CCha2ofd.js +0 -135
  732. package/dist/command-handlers-DCWJzHyB.js +0 -1609
  733. package/dist/command-registry-BIf61QNz.js +0 -9
  734. package/dist/command-registry-DJROBy4h.js +0 -4
  735. package/dist/command-registry-core-BQOWqi6S.js +0 -110
  736. package/dist/command-status.runtime-D88CUglL.js +0 -90
  737. package/dist/commands-acp-B-8dHX4Z.js +0 -74
  738. package/dist/commands-compact.runtime-ComX5mUk.js +0 -10
  739. package/dist/commands-handlers.runtime-DR3wjXHX.js +0 -6154
  740. package/dist/commands-status-CDyGrwsI.js +0 -3
  741. package/dist/commands-status-DV-i_ZIK.js +0 -16
  742. package/dist/commands-status.runtime-CDyGrwsI.js +0 -3
  743. package/dist/commands-subagents-control.runtime-B029cXAS.js +0 -3
  744. package/dist/commands-subagents-control.runtime-DR8Qspe0.js +0 -2
  745. package/dist/commands-system-prompt-C10ctsG3.js +0 -162
  746. package/dist/commands-system-prompt-DQlRWwnk.js +0 -2
  747. package/dist/commands.runtime-BYmIAuN0.js +0 -176
  748. package/dist/compact-14Ljaaeu.js +0 -480
  749. package/dist/compact-B--ovdkx.js +0 -1141
  750. package/dist/compact.runtime-E0Idf2Dq.js +0 -12
  751. package/dist/completion-cli-DMvvQGSk.js +0 -315
  752. package/dist/computer-use-CcLwX5SR.js +0 -367
  753. package/dist/config-B39SIZNb.js +0 -2
  754. package/dist/config-D4rsGOyV.js +0 -373
  755. package/dist/config-mutations-CsI3YJu7.js +0 -159
  756. package/dist/context-engine-host-compat-BZpDFiMJ.js +0 -2
  757. package/dist/context-engine-host-compat-runUdES5.js +0 -288
  758. package/dist/context-engine-lifecycle-D6odtNrn.js +0 -1274
  759. package/dist/control-auth-BPGpPtfz.js +0 -114
  760. package/dist/control-service-C-OmdPCe.js +0 -145
  761. package/dist/control-ui/assets/agents-GeyOHPuW.js +0 -1008
  762. package/dist/control-ui/assets/channel-config-extras-D7en6iUg.js +0 -2
  763. package/dist/control-ui/assets/channels-DkEyr1w5.js +0 -367
  764. package/dist/control-ui/assets/cron-C-wThQ1Q.js +0 -1013
  765. package/dist/control-ui/assets/debug-83AFRtIX.js +0 -97
  766. package/dist/control-ui/assets/index-CiGEhMOA.js +0 -7370
  767. package/dist/control-ui/assets/instances-CVl0t-1h.js +0 -57
  768. package/dist/control-ui/assets/logs-eybVEXxg.js +0 -74
  769. package/dist/control-ui/assets/nodes-C_A7eoU2.js +0 -436
  770. package/dist/control-ui/assets/sessions-Cq4Nc69u.js +0 -399
  771. package/dist/control-ui/assets/skills-ZN6hroIh.js +0 -314
  772. package/dist/control-ui/assets/skills-shared-DIWGwmdC.js +0 -11
  773. package/dist/conversation-binding-runtime-C2U1JElL.js +0 -4
  774. package/dist/conversation-runtime-NmIUd3Zu.js +0 -31
  775. package/dist/core-DGKJP1dm.js +0 -282
  776. package/dist/core-api-1fA4sNeC.js +0 -5
  777. package/dist/core-api-BY822Quq.js +0 -2
  778. package/dist/crestodian-Bp-NXiBC.js +0 -55
  779. package/dist/daocore-tools-Defpam0j.js +0 -11727
  780. package/dist/delivery-CEdVAUGB.js +0 -1002
  781. package/dist/dialogue-CZ69INPq.js +0 -37
  782. package/dist/dir-fetch-tool-BCicHhQE.js +0 -565
  783. package/dist/dir-list-tool-Cv_WktsJ.js +0 -100
  784. package/dist/direct-dm-Bz89rM8x.js +0 -64
  785. package/dist/directive-handling.fast-lane-DDnbcc5S.js +0 -68
  786. package/dist/directive-handling.impl-B0H52Ymr.js +0 -818
  787. package/dist/directive-handling.impl-CgKpwEW-.js +0 -2
  788. package/dist/directive-handling.model-selection-_cXAr0vt.js +0 -122
  789. package/dist/directive-handling.persist.runtime-Dw0mfzXT.js +0 -263
  790. package/dist/dispatch-C3AeYvyP.js +0 -1640
  791. package/dist/dispatch-acp-transcript.runtime-CP8pqBwS.js +0 -40
  792. package/dist/dispatch-acp.runtime-Cdap-AZI.js +0 -18
  793. package/dist/doctor-BZwVH97p.js +0 -2
  794. package/dist/doctor-BfkGBii1.js +0 -6
  795. package/dist/doctor-config-flow-D3JASGDt.js +0 -1741
  796. package/dist/doctor-core-checks-DH5AIT0Q.js +0 -573
  797. package/dist/doctor-core-checks-DiNu7VSh.js +0 -2
  798. package/dist/doctor-health-BDIJ-Nro.js +0 -65
  799. package/dist/doctor-health-contributions-BgmF7w8X.js +0 -696
  800. package/dist/doctor-lint-uIxkMUSO.js +0 -94
  801. package/dist/doctor-state-integrity-ws1b_BGk.js +0 -1231
  802. package/dist/doctor-update-Cx4CqxaX.js +0 -58
  803. package/dist/dynamic-tools-DiqOxhJh.js +0 -486
  804. package/dist/embedded-backend-C634irMl.js +0 -579
  805. package/dist/embedded-gateway-stub.runtime-CCfrTOeN.js +0 -12
  806. package/dist/exec-approvals-D85KThSg.js +0 -149
  807. package/dist/file-fetch-tool-BERaGYCT.js +0 -124
  808. package/dist/file-write-tool-BjHrMyfe.js +0 -127
  809. package/dist/format-DE9PuPg1.js +0 -1145
  810. package/dist/gateway-cli-B5hjhbUy.js +0 -435
  811. package/dist/gateway-method-runtime-Bu0E9Eki.js +0 -21
  812. package/dist/get-reply-6PtPz9hv.js +0 -4689
  813. package/dist/get-reply-from-config.runtime-CwprvhoR.js +0 -2
  814. package/dist/graph-users-DUp1kgnS.js +0 -1419
  815. package/dist/group-access-D5GBQ3w6.js +0 -112
  816. package/dist/handle-action.guild-admin-CA0Y-buD.js +0 -288
  817. package/dist/harness-B5nOFVfm.js +0 -61
  818. package/dist/health-D5heIDj3.js +0 -4
  819. package/dist/heartbeat-runner-BzFkIFHh.js +0 -5
  820. package/dist/heartbeat-runner.runtime-p6H1_xMV.js +0 -4
  821. package/dist/hooks-BvTyQ14X.js +0 -534
  822. package/dist/inbound-direct-dm-runtime-DwiDXi8L.js +0 -2
  823. package/dist/inbound-reply-dispatch-YoDUOC6C.js +0 -148
  824. package/dist/init-CPtcV5Xu.js +0 -59
  825. package/dist/inline-buttons-DeD5d42c.js +0 -40
  826. package/dist/internal-events-DEb50Sw3.js +0 -90
  827. package/dist/isolated-agent-CcxFFZ-Z.js +0 -1118
  828. package/dist/isolated-agent-CpHzq5qr.js +0 -2
  829. package/dist/lifecycle-DNel-oMe.js +0 -571
  830. package/dist/list.probe-DCa3N25d.js +0 -449
  831. package/dist/list.status-command-CyeAJmZW.js +0 -789
  832. package/dist/llm-slug-generator-CyqTY37Z.js +0 -78
  833. package/dist/local-dispatch.runtime-nE39kFIP.js +0 -9
  834. package/dist/manager.runtime-CpAPB8D5.js +0 -2714
  835. package/dist/markdown-to-line-Ci6TRmoZ.js +0 -811
  836. package/dist/mcp-http-BR0vmxFL.js +0 -2
  837. package/dist/mcp-http-C0oniA8h.js +0 -555
  838. package/dist/media-understanding-provider-BwA0XqC3.js +0 -339
  839. package/dist/message-actions-C9C_Ngkd.js +0 -145
  840. package/dist/message-handler-CUUKPC5n.js +0 -384
  841. package/dist/message-handler-xRTfIXWV.js +0 -1715
  842. package/dist/message-handler.preflight-Ch2Q7V3M.js +0 -1125
  843. package/dist/message-handler.process-HM3mK93q.js +0 -1484
  844. package/dist/model-CB8Ex5xS.js +0 -74
  845. package/dist/model-selection-2s0Dinux.js +0 -272
  846. package/dist/models-Cn-6DJ41.js +0 -2
  847. package/dist/models-CzszJD__.js +0 -104
  848. package/dist/models-cli-CbhElnA5.js +0 -256
  849. package/dist/monitor-7aprTsMV.js +0 -715
  850. package/dist/monitor-BuVhqwDS.js +0 -1370
  851. package/dist/monitor-C4H_YkgY.js +0 -2
  852. package/dist/monitor-CPQsMxgv.js +0 -1657
  853. package/dist/monitor-Ce0V1PiR.js +0 -4377
  854. package/dist/monitor-D0bcGJWI.js +0 -60
  855. package/dist/monitor-DEjlJqzh.js +0 -834
  856. package/dist/monitor-auth-DjJZsjgV.js +0 -179
  857. package/dist/monitor-ikSYagv3.js +0 -2788
  858. package/dist/monitor-polling.runtime-D7yEflMM.js +0 -883
  859. package/dist/monitor-webhook.runtime-CIZt-biI.js +0 -387
  860. package/dist/monitor.account-C2sMOBCS.js +0 -5233
  861. package/dist/monitor.runtime-BAi6zmcn.js +0 -2
  862. package/dist/monitor.webhook-BcjpfRCX.js +0 -180
  863. package/dist/node-cli-sessions-CIhkJRU4.js +0 -1228
  864. package/dist/openai-http-Dj21RwSj.js +0 -824
  865. package/dist/openresponses-http-COnnr1ox.js +0 -1173
  866. package/dist/operations-H3vUh0lM.js +0 -805
  867. package/dist/outbound-adapter-WLtWE7wv.js +0 -543
  868. package/dist/outbound-session-route-CZtd64EH.js +0 -45
  869. package/dist/outbound.runtime-D98P0sN1.js +0 -2
  870. package/dist/pi-embedded-BWJzd4mK.js +0 -4
  871. package/dist/pi-embedded-DeNsSqQQ.js +0 -3796
  872. package/dist/pi-embedded.runtime-CZnNwFpc.js +0 -4
  873. package/dist/pi-tools-CNHSpjBa.js +0 -2413
  874. package/dist/plan-B0reFFlM.js +0 -81
  875. package/dist/plan-CrfF-TH8.js +0 -112
  876. package/dist/plugin-DI_8eYOe.js +0 -12396
  877. package/dist/plugin-app-cache-key-WaTUD3e-.js +0 -46
  878. package/dist/plugin-enabled-aWLXgGGi.js +0 -233
  879. package/dist/plugin-registration-ByjRIVJm.js +0 -88
  880. package/dist/plugin-service-VQm_241d.js +0 -1229
  881. package/dist/policy-BmJH-swe.js +0 -680
  882. package/dist/policy-DE-bO1zn.js +0 -138
  883. package/dist/prepare.runtime-bSj3-res.js +0 -732
  884. package/dist/preview-warnings-CbuGYsF9.js +0 -392
  885. package/dist/probe-C_rWg7_m.js +0 -682
  886. package/dist/probe-CagOFfx6.js +0 -2
  887. package/dist/probe-thX1HqOh.js +0 -2204
  888. package/dist/probe-zU6B6gFt.js +0 -47
  889. package/dist/program-BtVdH743.js +0 -131
  890. package/dist/provider-CDoD7tO0.js +0 -8735
  891. package/dist/provider-CK1gMdJ2.js +0 -32
  892. package/dist/provider-DJqr9djy.js +0 -32
  893. package/dist/provider-DsOJp5bK.js +0 -152
  894. package/dist/provider-dispatcher-UNQ-LSx9.js +0 -22
  895. package/dist/provider-session.runtime-DMrkMb4x.js +0 -9
  896. package/dist/provider.runtime-C2-t3zm8.js +0 -2
  897. package/dist/public-surface-loader-hTeyyHcd.js +0 -114
  898. package/dist/pw-ai-BaL3eVYx.js +0 -3029
  899. package/dist/pw-role-snapshot-DKeBqhN1.js +0 -333
  900. package/dist/reaction-level-BV2potsD.js +0 -19
  901. package/dist/reaction-runtime-api-CCBxgM10.js +0 -116
  902. package/dist/realtime-transcription-provider-CHYtIXZm.js +0 -205
  903. package/dist/register-BJf28G9B.js +0 -2178
  904. package/dist/register.agent-oXAHwNQv.js +0 -156
  905. package/dist/register.crestodian-CQ0sqdV2.js +0 -24
  906. package/dist/register.maintenance-CylVRs5M.js +0 -83
  907. package/dist/register.runtime-CcDgwy0X.js +0 -54
  908. package/dist/register.subclis-CpBYNw2X.js +0 -3
  909. package/dist/register.subclis-N2CvieOL.js +0 -31
  910. package/dist/register.subclis-core-BHaGvbzg.js +0 -273
  911. package/dist/repair-sequencing-EBBnBdIB.js +0 -640
  912. package/dist/reply-delivery-BLoPALlI.js +0 -196
  913. package/dist/reply-runtime-D4asNTSa.js +0 -11
  914. package/dist/reply.runtime-CwprvhoR.js +0 -2
  915. package/dist/request-DlWPRUDt.js +0 -54
  916. package/dist/resolve-allowlist-BukQf58x.js +0 -220
  917. package/dist/result-fallback-classifier-DyHFnqfV.js +0 -79
  918. package/dist/route-BMf4keN5.js +0 -469
  919. package/dist/route-resolution-DWNi1QAu.js +0 -274
  920. package/dist/routes-C20LC8c4.js +0 -3602
  921. package/dist/routes-CkK7Vv_m.js +0 -2
  922. package/dist/run-KDF_AEza.js +0 -1162
  923. package/dist/run-attempt-JHYCfonU.js +0 -7704
  924. package/dist/run-command-3PVihYIy.js +0 -2
  925. package/dist/run-command-QHAXnyKY.js +0 -23
  926. package/dist/run-embedded.runtime-BJw-2vss.js +0 -4
  927. package/dist/run-execution-cli.runtime-GHClMn2g.js +0 -4
  928. package/dist/run-subagent-registry.runtime-BLLMrhtE.js +0 -2
  929. package/dist/runtime-C2u-dC1r.js +0 -1287
  930. package/dist/runtime-ClyfkDWT.js +0 -6179
  931. package/dist/runtime-WXCarlPc.js +0 -438
  932. package/dist/runtime-api-3QhGLpZf.js +0 -13
  933. package/dist/runtime-api-DRAu3mjv.js +0 -4
  934. package/dist/runtime-api-JE07pOem.js +0 -13
  935. package/dist/runtime-api-JuKylHvw.js +0 -24
  936. package/dist/runtime-api-bcbk4yax.js +0 -21
  937. package/dist/runtime-api-dDe9U2_V.js +0 -17
  938. package/dist/runtime-api-uMexLqGS.js +0 -3
  939. package/dist/runtime-api.actions-Bo7TLDFl.js +0 -3
  940. package/dist/runtime-api.monitor-7q78L1Em.js +0 -6
  941. package/dist/runtime-api.send-Bf9RR4nV.js +0 -4
  942. package/dist/runtime-api.threads-Dj2QuhHj.js +0 -2
  943. package/dist/runtime-channel-k1C0Satl.js +0 -2
  944. package/dist/runtime-channel-qt9t0J-J.js +0 -150
  945. package/dist/runtime-embedded-pi.runtime-BPB9NlTS.js +0 -2
  946. package/dist/sanitize-outbound-BLH_SQvg.js +0 -127
  947. package/dist/sdk-setup-tools-BshlBPau.js +0 -8
  948. package/dist/secrets-CsHXv7d3.js +0 -113
  949. package/dist/security-audit-CUXBQXNX.js +0 -122
  950. package/dist/security-audit-CzdXbRma.js +0 -118
  951. package/dist/security-audit.runtime-Ca0FMFJG.js +0 -2
  952. package/dist/selection-BmvQJlSD.js +0 -3
  953. package/dist/selection-BplDXc9w.js +0 -16157
  954. package/dist/send--qFg8a9v.js +0 -1631
  955. package/dist/send-BPdryPPA.js +0 -192
  956. package/dist/send-Bl4YaRkS.js +0 -143
  957. package/dist/send-Ccm7RMXC.js +0 -2
  958. package/dist/send.components-c3OUPSmR.js +0 -2
  959. package/dist/send.components-rhQJYoXs.js +0 -500
  960. package/dist/send.runtime-dfUkAp5d.js +0 -2
  961. package/dist/server-DRhyTMLe.js +0 -73
  962. package/dist/server-Dv4BzjGn.js +0 -24
  963. package/dist/server-context-4HRJy2vp.js +0 -955
  964. package/dist/server-context-DlxYb1G5.js +0 -2
  965. package/dist/server-cron-Bt8Pkc3i.js +0 -2989
  966. package/dist/server-cron-CtNWsa4Z.js +0 -2
  967. package/dist/server-methods-rye_okUW.js +0 -16494
  968. package/dist/server-node-events-C1yZ5a1u.js +0 -596
  969. package/dist/server-plugin-bootstrap-DUMyVtlP.js +0 -70
  970. package/dist/server-plugins-B5ZWWkRE.js +0 -432
  971. package/dist/server-reload-handlers-CTnMXNjT.js +0 -714
  972. package/dist/server-restart-sentinel-CAYxtwmY.js +0 -747
  973. package/dist/server-restart-sentinel-DqrtSIvy.js +0 -2
  974. package/dist/server-runtime-services-CuptQTe5.js +0 -2
  975. package/dist/server-runtime-services-aaS2IiW3.js +0 -267
  976. package/dist/server-startup-plugins-D0ymJgQT.js +0 -113
  977. package/dist/server-startup-post-attach-DlrN2uyt.js +0 -716
  978. package/dist/server-ws-runtime-CdpLbv4o.js +0 -349
  979. package/dist/server.impl-Cb4qcMTg.js +0 -2586
  980. package/dist/service-qxvDlMQE.js +0 -1446
  981. package/dist/session-binding-6bLobLHL.js +0 -219
  982. package/dist/session-binding-Bm6fCpoY.js +0 -2
  983. package/dist/session-kill-http-B6WjVo8V.js +0 -121
  984. package/dist/session-reset-service-GUVIhxp4.js +0 -625
  985. package/dist/session-route-BcRDnvzG.js +0 -93
  986. package/dist/session-status.runtime-BcjOunV4.js +0 -2
  987. package/dist/session-subagent-reactivation.runtime-BSmk_KYn.js +0 -2
  988. package/dist/session-tab-registry-BBYzbSOu.js +0 -521
  989. package/dist/sessions-history-http-bLJJfgLm.js +0 -430
  990. package/dist/sessions.runtime-DNRtQzCk.js +0 -2
  991. package/dist/setup-api-CcolVVJs.js +0 -29
  992. package/dist/setup-core-eJD18F3B.js +0 -174
  993. package/dist/setup-surface-B75C2Qtz.js +0 -221
  994. package/dist/setup-surface-CFuPfVHp.js +0 -405
  995. package/dist/setup-surface-Dyy-Mzyz.js +0 -288
  996. package/dist/setup-surface-ZsVF_g8W.js +0 -320
  997. package/dist/shared-BkCNrcLX.js +0 -121
  998. package/dist/shared-client-B7zqC9p2.js +0 -2
  999. package/dist/shared-client-yXjKgZBz.js +0 -629
  1000. package/dist/side-question-DU3gESCb.js +0 -683
  1001. package/dist/skill-tool-dispatch.runtime-CPBuqyvk.js +0 -143
  1002. package/dist/slash-state-Do3bAahA.js +0 -2166
  1003. package/dist/speech-provider-Bg9los3C.js +0 -184
  1004. package/dist/src-D7LzUctH.js +0 -4256
  1005. package/dist/startup-context-CCF2gIOl.js +0 -313
  1006. package/dist/status-subagents.runtime-DX5FTymp.js +0 -18
  1007. package/dist/status-text-B-1u5dSV.js +0 -296
  1008. package/dist/sticker-cache-DwpU_9RJ.js +0 -206
  1009. package/dist/sticker-vision.runtime-Bbldi_YL.js +0 -17
  1010. package/dist/subagent-announce-BCo0VHVL.js +0 -354
  1011. package/dist/subagent-announce-delivery-JcnuDN_N.js +0 -958
  1012. package/dist/subagent-control-BzbA3Suz.js +0 -508
  1013. package/dist/subagent-hooks-BIGZQWrG.js +0 -2
  1014. package/dist/subagent-hooks-Bj4qYZfv.js +0 -230
  1015. package/dist/subagent-hooks-C-rvhVBv.js +0 -2
  1016. package/dist/subagent-hooks-P01_AFl5.js +0 -116
  1017. package/dist/subagent-hooks-VEfak8nl.js +0 -2
  1018. package/dist/subagent-hooks-api-BPnSxxN4.js +0 -23
  1019. package/dist/subagent-hooks-api-DwIAvMoS.js +0 -22
  1020. package/dist/subagent-hooks-api-kgyR9FOb.js +0 -23
  1021. package/dist/subagent-hooks-oED56wqq.js +0 -146
  1022. package/dist/subagent-orphan-recovery-D79ZzwKN.js +0 -352
  1023. package/dist/subagent-registry-D0soBT5j.js +0 -2351
  1024. package/dist/subagent-registry-DRJDkmty.js +0 -3
  1025. package/dist/subagent-session-cleanup-9eAO1aJe.js +0 -525
  1026. package/dist/subagent-spawn-D80vbogm.js +0 -1164
  1027. package/dist/target-id-COLv5LsJ.js +0 -107
  1028. package/dist/targets-CDW5IQ6a.js +0 -44
  1029. package/dist/targets-Ci6O1ZdP.js +0 -19
  1030. package/dist/targets-CsaWFBg1.js +0 -19
  1031. package/dist/testing-BoJit-h1.js +0 -267
  1032. package/dist/thread-bindings-CGCvw0KT.js +0 -571
  1033. package/dist/thread-bindings-ClCTNacX.js +0 -228
  1034. package/dist/thread-bindings-DRb7BMZ6.js +0 -8
  1035. package/dist/thread-bindings-Xc6smav0.js +0 -232
  1036. package/dist/thread-bindings.discord-api-DC467oeF.js +0 -187
  1037. package/dist/thread-bindings.manager-C_mpTDIZ.js +0 -536
  1038. package/dist/thread-bindings.manager-DkCRs612.js +0 -2
  1039. package/dist/thread-lifecycle-DpqCXlx9.js +0 -1614
  1040. package/dist/token-CI6HjbTA.js +0 -134
  1041. package/dist/tool-BMe7hjBK.js +0 -139
  1042. package/dist/tool-actions.runtime-D-h5PI_m.js +0 -534
  1043. package/dist/tool-resolution-CnLx0CHe.js +0 -149
  1044. package/dist/tools-effective-inventory-BR6MUMtE.js +0 -204
  1045. package/dist/tools-invoke-http-CTTs2yMT.js +0 -67
  1046. package/dist/tools-invoke-shared-9B1EjXWf.js +0 -200
  1047. package/dist/tts-eGOviZ5c.js +0 -66
  1048. package/dist/tui-Bw0HqKd7.js +0 -4709
  1049. package/dist/tui-CIZJnPzj.js +0 -2
  1050. package/dist/tui-backend-BJ_r7tcF.js +0 -256
  1051. package/dist/tui-cli-BaSMBpuA.js +0 -37
  1052. package/dist/update-cli-zuCybGNR.js +0 -3664
  1053. package/dist/update-runner-Dek2BHmQ.js +0 -2379
  1054. package/dist/vision-tools-1ps0BEE5.js +0 -1409
  1055. package/dist/web-search-B7EziZXE.js +0 -62
  1056. package/dist/web-search-provider.runtime-DGTCvGch.js +0 -328
  1057. package/dist/web-search-provider.runtime-DWL5t39M.js +0 -2
  1058. package/dist/xai-oauth-CRtsj2Gs.js +0 -479
  1059. package/dist/xai-user-agent-Dndwzw2S.js +0 -32
  1060. /package/dist/{acp-runtime-backend-DSDBcyh9.js → acp-runtime-backend-Cxo7eBHf.js} +0 -0
  1061. /package/dist/{channel-actions-FV66JqtI.js → channel-actions-UDeVjgGz.js} +0 -0
  1062. /package/dist/{command-status-runtime-BRWKSoG7.js → command-status-runtime-CoHd4Fws.js} +0 -0
  1063. /package/dist/{delegate-DGqKhwB4.js → delegate-B-2xZ77o.js} +0 -0
  1064. /package/dist/{dispatch-acp-Ceoxja_Z.js → dispatch-acp-DLPkmK7K.js} +0 -0
  1065. /package/dist/{heartbeat-runner-CJHvr5pG.js → heartbeat-runner-D2j6JwOI.js} +0 -0
  1066. /package/dist/{library-Bq3aDek_.js → library-DBT0cIPP.js} +0 -0
  1067. /package/dist/{run-executor.runtime-DNJhGPbA.js → run-executor.runtime-DE4J7f4M.js} +0 -0
  1068. /package/dist/{shared-CYxmRpq1.js → shared-xeo8Yh5n.js} +0 -0
@@ -1,1496 +0,0 @@
1
- import { i as formatErrorMessage } from "./errors-D_oyTIw2.js";
2
- import { t as DEFAULT_ACCOUNT_ID } from "./account-id-B32J-iNN.js";
3
- import { Et as array, Nn as record, Rn as string, Tn as object, Zn as unknown, dn as literal, wn as number, yt as _enum } from "./schemas-Del5uzR8.js";
4
- import { t as safeParseJsonWithSchema } from "./zod-parse-B4dzFRWI.js";
5
- import { t as privateFileStore } from "./private-file-store-C_5ZwE9L.js";
6
- import { r as buildChannelConfigSchema } from "./config-schema-CpJ4LFf2.js";
7
- import { o as resolveStableChannelMessageIngress } from "./runtime-W39pAdFK.js";
8
- import { l as createScopedDmSecurityResolver, u as createTopLevelChannelConfigAdapter } from "./channel-config-helpers-CQb9YOAn.js";
9
- import { n as formatPairingApproveHint } from "./helpers-DII7kv8Y.js";
10
- import "./error-runtime--zM-GsR-.js";
11
- import { n as describeAccountSnapshot } from "./account-helpers-BEXOONiv.js";
12
- import { i as createChatChannelPlugin, t as buildChannelOutboundSessionRoute, u as stripChannelTargetPrefix } from "./core-DGKJP1dm.js";
13
- import "./channel-core-nm8s1qFZ.js";
14
- import { t as createPluginRuntimeStore } from "./runtime-store-BSkCngaf.js";
15
- import "./security-runtime-Q5KQBgu1.js";
16
- import { t as createDirectDmPreCryptoGuardPolicy } from "./direct-dm-guard-policy-Bi3caG-G.js";
17
- import { c as collectStatusIssuesFromLastError, d as createDefaultChannelRuntimeState, u as createComputedAccountStatusAdapter } from "./status-helpers-nyf_mfYa.js";
18
- import { r as buildTrafficStatusSummary, t as buildPassiveChannelStatusSummary } from "./extension-shared-D6I0yOLZ.js";
19
- import "./channel-ingress-runtime-BZvnfysR.js";
20
- import { k as createChannelMessageAdapterFromOutbound } from "./channel-message-YAmKOwAT.js";
21
- import { n as createChannelPairingController } from "./channel-pairing-BQeyBt0a.js";
22
- import { t as attachChannelToResult } from "./channel-send-result-swFdRKhg.js";
23
- import { n as NostrProfileSchema, t as NostrConfigSchema } from "./config-schema-C-NqMGUr.js";
24
- import { a as resolveNostrAccount, c as SimplePool, d as verifyEvent, f as cbc, g as randomBytes, h as hexToBytes, i as resolveDefaultNostrAccountId, l as finalizeEvent, m as secp256k1, n as nostrSetupWizard, o as normalizePubkey, p as base64, r as listNostrAccountIds, s as validatePrivateKey, t as nostrSetupAdapter, u as getPublicKey } from "./setup-surface-D9HaNHKN.js";
25
- import { i as DEFAULT_RELAYS } from "./setup-adapter-DMuZmn45.js";
26
- import path from "node:path";
27
- import os from "node:os";
28
- //#region node_modules/nostr-tools/lib/esm/nip04.js
29
- var utf8Decoder = new TextDecoder("utf-8");
30
- var utf8Encoder = new TextEncoder();
31
- function encrypt(secretKey, pubkey, text) {
32
- const privkey = secretKey instanceof Uint8Array ? secretKey : hexToBytes(secretKey);
33
- const normalizedKey = getNormalizedX(secp256k1.getSharedSecret(privkey, hexToBytes("02" + pubkey)));
34
- let iv = Uint8Array.from(randomBytes(16));
35
- let plaintext = utf8Encoder.encode(text);
36
- let ciphertext = cbc(normalizedKey, iv).encrypt(plaintext);
37
- return `${base64.encode(new Uint8Array(ciphertext))}?iv=${base64.encode(new Uint8Array(iv.buffer))}`;
38
- }
39
- function decrypt(secretKey, pubkey, data) {
40
- const privkey = secretKey instanceof Uint8Array ? secretKey : hexToBytes(secretKey);
41
- let [ctb64, ivb64] = data.split("?iv=");
42
- let normalizedKey = getNormalizedX(secp256k1.getSharedSecret(privkey, hexToBytes("02" + pubkey)));
43
- let iv = base64.decode(ivb64);
44
- let ciphertext = base64.decode(ctb64);
45
- let plaintext = cbc(normalizedKey, iv).decrypt(ciphertext);
46
- return utf8Decoder.decode(plaintext);
47
- }
48
- function getNormalizedX(key) {
49
- return key.slice(1, 33);
50
- }
51
- //#endregion
52
- //#region extensions/nostr/src/metrics.ts
53
- /**
54
- * Create a metrics collector instance.
55
- * Optionally pass an onMetric callback to receive real-time metric events.
56
- */
57
- function createMetrics(onMetric) {
58
- let eventsReceived = 0;
59
- let eventsProcessed = 0;
60
- let eventsDuplicate = 0;
61
- const eventsRejected = {
62
- invalidShape: 0,
63
- wrongKind: 0,
64
- stale: 0,
65
- future: 0,
66
- rateLimited: 0,
67
- invalidSignature: 0,
68
- oversizedCiphertext: 0,
69
- oversizedPlaintext: 0,
70
- decryptFailed: 0,
71
- selfMessage: 0
72
- };
73
- const relays = /* @__PURE__ */ new Map();
74
- const rateLimiting = {
75
- perSenderHits: 0,
76
- globalHits: 0
77
- };
78
- const decrypt = {
79
- success: 0,
80
- failure: 0
81
- };
82
- const memory = {
83
- seenTrackerSize: 0,
84
- rateLimiterEntries: 0
85
- };
86
- function getOrCreateRelay(url) {
87
- let relay = relays.get(url);
88
- if (!relay) {
89
- relay = {
90
- connects: 0,
91
- disconnects: 0,
92
- reconnects: 0,
93
- errors: 0,
94
- messagesReceived: {
95
- event: 0,
96
- eose: 0,
97
- closed: 0,
98
- notice: 0,
99
- ok: 0,
100
- auth: 0
101
- },
102
- circuitBreakerState: "closed",
103
- circuitBreakerOpens: 0,
104
- circuitBreakerCloses: 0
105
- };
106
- relays.set(url, relay);
107
- }
108
- return relay;
109
- }
110
- function emit(name, value = 1, labels) {
111
- if (onMetric) onMetric({
112
- name,
113
- value,
114
- timestamp: Date.now(),
115
- labels
116
- });
117
- const relayUrl = labels?.relay;
118
- switch (name) {
119
- case "event.received":
120
- eventsReceived += value;
121
- break;
122
- case "event.processed":
123
- eventsProcessed += value;
124
- break;
125
- case "event.duplicate":
126
- eventsDuplicate += value;
127
- break;
128
- case "event.rejected.invalid_shape":
129
- eventsRejected.invalidShape += value;
130
- break;
131
- case "event.rejected.wrong_kind":
132
- eventsRejected.wrongKind += value;
133
- break;
134
- case "event.rejected.stale":
135
- eventsRejected.stale += value;
136
- break;
137
- case "event.rejected.future":
138
- eventsRejected.future += value;
139
- break;
140
- case "event.rejected.rate_limited":
141
- eventsRejected.rateLimited += value;
142
- break;
143
- case "event.rejected.invalid_signature":
144
- eventsRejected.invalidSignature += value;
145
- break;
146
- case "event.rejected.oversized_ciphertext":
147
- eventsRejected.oversizedCiphertext += value;
148
- break;
149
- case "event.rejected.oversized_plaintext":
150
- eventsRejected.oversizedPlaintext += value;
151
- break;
152
- case "event.rejected.decrypt_failed":
153
- eventsRejected.decryptFailed += value;
154
- break;
155
- case "event.rejected.self_message":
156
- eventsRejected.selfMessage += value;
157
- break;
158
- case "relay.connect":
159
- if (relayUrl) getOrCreateRelay(relayUrl).connects += value;
160
- break;
161
- case "relay.disconnect":
162
- if (relayUrl) getOrCreateRelay(relayUrl).disconnects += value;
163
- break;
164
- case "relay.reconnect":
165
- if (relayUrl) getOrCreateRelay(relayUrl).reconnects += value;
166
- break;
167
- case "relay.error":
168
- if (relayUrl) getOrCreateRelay(relayUrl).errors += value;
169
- break;
170
- case "relay.message.event":
171
- if (relayUrl) getOrCreateRelay(relayUrl).messagesReceived.event += value;
172
- break;
173
- case "relay.message.eose":
174
- if (relayUrl) getOrCreateRelay(relayUrl).messagesReceived.eose += value;
175
- break;
176
- case "relay.message.closed":
177
- if (relayUrl) getOrCreateRelay(relayUrl).messagesReceived.closed += value;
178
- break;
179
- case "relay.message.notice":
180
- if (relayUrl) getOrCreateRelay(relayUrl).messagesReceived.notice += value;
181
- break;
182
- case "relay.message.ok":
183
- if (relayUrl) getOrCreateRelay(relayUrl).messagesReceived.ok += value;
184
- break;
185
- case "relay.message.auth":
186
- if (relayUrl) getOrCreateRelay(relayUrl).messagesReceived.auth += value;
187
- break;
188
- case "relay.circuit_breaker.open":
189
- if (relayUrl) {
190
- const r = getOrCreateRelay(relayUrl);
191
- r.circuitBreakerState = "open";
192
- r.circuitBreakerOpens += value;
193
- }
194
- break;
195
- case "relay.circuit_breaker.close":
196
- if (relayUrl) {
197
- const r = getOrCreateRelay(relayUrl);
198
- r.circuitBreakerState = "closed";
199
- r.circuitBreakerCloses += value;
200
- }
201
- break;
202
- case "relay.circuit_breaker.half_open":
203
- if (relayUrl) getOrCreateRelay(relayUrl).circuitBreakerState = "half_open";
204
- break;
205
- case "rate_limit.per_sender":
206
- rateLimiting.perSenderHits += value;
207
- break;
208
- case "rate_limit.global":
209
- rateLimiting.globalHits += value;
210
- break;
211
- case "decrypt.success":
212
- decrypt.success += value;
213
- break;
214
- case "decrypt.failure":
215
- decrypt.failure += value;
216
- break;
217
- case "memory.seen_tracker_size":
218
- memory.seenTrackerSize = value;
219
- break;
220
- case "memory.rate_limiter_entries":
221
- memory.rateLimiterEntries = value;
222
- break;
223
- }
224
- }
225
- function getSnapshot() {
226
- const relaysObj = {};
227
- for (const [url, stats] of relays) relaysObj[url] = {
228
- ...stats,
229
- messagesReceived: { ...stats.messagesReceived }
230
- };
231
- return {
232
- eventsReceived,
233
- eventsProcessed,
234
- eventsDuplicate,
235
- eventsRejected: { ...eventsRejected },
236
- relays: relaysObj,
237
- rateLimiting: { ...rateLimiting },
238
- decrypt: { ...decrypt },
239
- memory: { ...memory },
240
- snapshotAt: Date.now()
241
- };
242
- }
243
- function reset() {
244
- eventsReceived = 0;
245
- eventsProcessed = 0;
246
- eventsDuplicate = 0;
247
- Object.assign(eventsRejected, {
248
- invalidShape: 0,
249
- wrongKind: 0,
250
- stale: 0,
251
- future: 0,
252
- rateLimited: 0,
253
- invalidSignature: 0,
254
- oversizedCiphertext: 0,
255
- oversizedPlaintext: 0,
256
- decryptFailed: 0,
257
- selfMessage: 0
258
- });
259
- relays.clear();
260
- rateLimiting.perSenderHits = 0;
261
- rateLimiting.globalHits = 0;
262
- decrypt.success = 0;
263
- decrypt.failure = 0;
264
- memory.seenTrackerSize = 0;
265
- memory.rateLimiterEntries = 0;
266
- }
267
- return {
268
- emit,
269
- getSnapshot,
270
- reset
271
- };
272
- }
273
- /**
274
- * Create a no-op metrics instance (for when metrics are disabled).
275
- */
276
- function createNoopMetrics() {
277
- const emptySnapshot = {
278
- eventsReceived: 0,
279
- eventsProcessed: 0,
280
- eventsDuplicate: 0,
281
- eventsRejected: {
282
- invalidShape: 0,
283
- wrongKind: 0,
284
- stale: 0,
285
- future: 0,
286
- rateLimited: 0,
287
- invalidSignature: 0,
288
- oversizedCiphertext: 0,
289
- oversizedPlaintext: 0,
290
- decryptFailed: 0,
291
- selfMessage: 0
292
- },
293
- relays: {},
294
- rateLimiting: {
295
- perSenderHits: 0,
296
- globalHits: 0
297
- },
298
- decrypt: {
299
- success: 0,
300
- failure: 0
301
- },
302
- memory: {
303
- seenTrackerSize: 0,
304
- rateLimiterEntries: 0
305
- },
306
- snapshotAt: 0
307
- };
308
- return {
309
- emit: () => {},
310
- getSnapshot: () => ({
311
- ...emptySnapshot,
312
- snapshotAt: Date.now()
313
- }),
314
- reset: () => {}
315
- };
316
- }
317
- //#endregion
318
- //#region extensions/nostr/src/nostr-profile-core.ts
319
- /**
320
- * Convert our config profile schema to NIP-01 content format.
321
- * Strips undefined fields and validates URLs.
322
- */
323
- function profileToContent(profile) {
324
- const validated = NostrProfileSchema.parse(profile);
325
- const content = {};
326
- if (validated.name !== void 0) content.name = validated.name;
327
- if (validated.displayName !== void 0) content.display_name = validated.displayName;
328
- if (validated.about !== void 0) content.about = validated.about;
329
- if (validated.picture !== void 0) content.picture = validated.picture;
330
- if (validated.banner !== void 0) content.banner = validated.banner;
331
- if (validated.website !== void 0) content.website = validated.website;
332
- if (validated.nip05 !== void 0) content.nip05 = validated.nip05;
333
- if (validated.lud16 !== void 0) content.lud16 = validated.lud16;
334
- return content;
335
- }
336
- /**
337
- * Convert NIP-01 content format back to our config profile schema.
338
- * Useful for importing existing profiles from relays.
339
- */
340
- function contentToProfile(content) {
341
- const profile = {};
342
- if (content.name !== void 0) profile.name = content.name;
343
- if (content.display_name !== void 0) profile.displayName = content.display_name;
344
- if (content.about !== void 0) profile.about = content.about;
345
- if (content.picture !== void 0) profile.picture = content.picture;
346
- if (content.banner !== void 0) profile.banner = content.banner;
347
- if (content.website !== void 0) profile.website = content.website;
348
- if (content.nip05 !== void 0) profile.nip05 = content.nip05;
349
- if (content.lud16 !== void 0) profile.lud16 = content.lud16;
350
- return profile;
351
- }
352
- //#endregion
353
- //#region extensions/nostr/src/nostr-profile.ts
354
- /**
355
- * Nostr Profile Management (NIP-01 kind:0)
356
- *
357
- * Profile events are "replaceable" - the latest created_at wins.
358
- * This module handles profile event creation and publishing.
359
- */
360
- /**
361
- * Create a signed kind:0 profile event.
362
- *
363
- * @param sk - Private key as Uint8Array (32 bytes)
364
- * @param profile - Profile data to include
365
- * @param lastPublishedAt - Previous profile timestamp (for monotonic guarantee)
366
- * @returns Signed Nostr event
367
- */
368
- function createProfileEvent(sk, profile, lastPublishedAt) {
369
- const content = profileToContent(profile);
370
- const contentJson = JSON.stringify(content);
371
- const now = Math.floor(Date.now() / 1e3);
372
- return finalizeEvent({
373
- kind: 0,
374
- content: contentJson,
375
- tags: [],
376
- created_at: lastPublishedAt !== void 0 ? Math.max(now, lastPublishedAt + 1) : now
377
- }, sk);
378
- }
379
- /** Per-relay publish timeout (ms) */
380
- const RELAY_PUBLISH_TIMEOUT_MS = 5e3;
381
- /**
382
- * Publish a profile event to multiple relays.
383
- *
384
- * Best-effort: publishes to all relays in parallel, reports per-relay results.
385
- * Does NOT retry automatically - caller should handle retries if needed.
386
- *
387
- * @param pool - SimplePool instance for relay connections
388
- * @param relays - Array of relay WebSocket URLs
389
- * @param event - Signed profile event (kind:0)
390
- * @returns Publish results with successes and failures
391
- */
392
- async function publishProfileEvent(pool, relays, event) {
393
- const successes = [];
394
- const failures = [];
395
- const publishPromises = relays.map(async (relay) => {
396
- try {
397
- const timeoutPromise = new Promise((_, reject) => {
398
- setTimeout(() => reject(/* @__PURE__ */ new Error("timeout")), RELAY_PUBLISH_TIMEOUT_MS);
399
- });
400
- await Promise.race([...pool.publish([relay], event), timeoutPromise]);
401
- successes.push(relay);
402
- } catch (err) {
403
- const errorMessage = formatErrorMessage(err);
404
- failures.push({
405
- relay,
406
- error: errorMessage
407
- });
408
- }
409
- });
410
- await Promise.all(publishPromises);
411
- return {
412
- eventId: event.id,
413
- successes,
414
- failures,
415
- createdAt: event.created_at
416
- };
417
- }
418
- /**
419
- * Create and publish a profile event in one call.
420
- *
421
- * @param pool - SimplePool instance
422
- * @param sk - Private key as Uint8Array
423
- * @param relays - Array of relay URLs
424
- * @param profile - Profile data
425
- * @param lastPublishedAt - Previous timestamp for monotonic ordering
426
- * @returns Publish results
427
- */
428
- async function publishProfile(pool, sk, relays, profile, lastPublishedAt) {
429
- return publishProfileEvent(pool, relays, createProfileEvent(sk, profile, lastPublishedAt));
430
- }
431
- //#endregion
432
- //#region extensions/nostr/src/runtime.ts
433
- const { setRuntime: setNostrRuntime, getRuntime: getNostrRuntime } = createPluginRuntimeStore({
434
- pluginId: "nostr",
435
- errorMessage: "Nostr runtime not initialized"
436
- });
437
- //#endregion
438
- //#region extensions/nostr/src/nostr-state-store.ts
439
- const STORE_VERSION = 2;
440
- const PROFILE_STATE_VERSION = 1;
441
- const NullableFiniteNumberSchema = number().finite().nullable().catch(null);
442
- const NostrBusStateV1Schema = object({
443
- version: literal(1),
444
- lastProcessedAt: NullableFiniteNumberSchema,
445
- gatewayStartedAt: NullableFiniteNumberSchema
446
- });
447
- const NostrBusStateSchema = object({
448
- version: literal(2),
449
- lastProcessedAt: NullableFiniteNumberSchema,
450
- gatewayStartedAt: NullableFiniteNumberSchema,
451
- recentEventIds: array(unknown()).catch([]).transform((ids) => ids.filter((id) => typeof id === "string"))
452
- });
453
- const NostrProfileStateSchema = object({
454
- version: literal(1),
455
- lastPublishedAt: NullableFiniteNumberSchema,
456
- lastPublishedEventId: string().nullable().catch(null),
457
- lastPublishResults: record(string(), _enum([
458
- "ok",
459
- "failed",
460
- "timeout"
461
- ])).nullable().catch(null)
462
- });
463
- function normalizeAccountId(accountId) {
464
- const trimmed = accountId?.trim();
465
- if (!trimmed) return "default";
466
- return trimmed.replace(/[^a-z0-9._-]+/gi, "_");
467
- }
468
- function resolveNostrStatePath(accountId, env = process.env) {
469
- const stateDir = getNostrRuntime().state.resolveStateDir(env, os.homedir);
470
- const normalized = normalizeAccountId(accountId);
471
- return path.join(stateDir, "nostr", `bus-state-${normalized}.json`);
472
- }
473
- function resolveNostrProfileStatePath(accountId, env = process.env) {
474
- const stateDir = getNostrRuntime().state.resolveStateDir(env, os.homedir);
475
- const normalized = normalizeAccountId(accountId);
476
- return path.join(stateDir, "nostr", `profile-state-${normalized}.json`);
477
- }
478
- function safeParseState(raw) {
479
- const parsedV2 = safeParseJsonWithSchema(NostrBusStateSchema, raw);
480
- if (parsedV2) return parsedV2;
481
- const parsedV1 = safeParseJsonWithSchema(NostrBusStateV1Schema, raw);
482
- if (!parsedV1) return null;
483
- return {
484
- version: 2,
485
- lastProcessedAt: parsedV1.lastProcessedAt,
486
- gatewayStartedAt: parsedV1.gatewayStartedAt,
487
- recentEventIds: []
488
- };
489
- }
490
- async function readNostrBusState(params) {
491
- const filePath = resolveNostrStatePath(params.accountId, params.env);
492
- try {
493
- const raw = await privateFileStore(path.dirname(filePath)).readTextIfExists(path.basename(filePath));
494
- if (raw === null) return null;
495
- return safeParseState(raw);
496
- } catch {
497
- return null;
498
- }
499
- }
500
- async function writeNostrBusState(params) {
501
- const filePath = resolveNostrStatePath(params.accountId, params.env);
502
- const payload = {
503
- version: STORE_VERSION,
504
- lastProcessedAt: params.lastProcessedAt,
505
- gatewayStartedAt: params.gatewayStartedAt,
506
- recentEventIds: (params.recentEventIds ?? []).filter((x) => typeof x === "string")
507
- };
508
- await privateFileStore(path.dirname(filePath)).writeJson(path.basename(filePath), payload, { trailingNewline: true });
509
- }
510
- /**
511
- * Determine the `since` timestamp for subscription.
512
- * Returns the later of: lastProcessedAt or gatewayStartedAt (both from disk),
513
- * falling back to `now` for fresh starts.
514
- */
515
- function computeSinceTimestamp(state, nowSec = Math.floor(Date.now() / 1e3)) {
516
- if (!state) return nowSec;
517
- const candidates = [state.lastProcessedAt, state.gatewayStartedAt].filter((t) => t !== null && t > 0);
518
- if (candidates.length === 0) return nowSec;
519
- return Math.max(...candidates);
520
- }
521
- function safeParseProfileState(raw) {
522
- return safeParseJsonWithSchema(NostrProfileStateSchema, raw);
523
- }
524
- async function readNostrProfileState(params) {
525
- const filePath = resolveNostrProfileStatePath(params.accountId, params.env);
526
- try {
527
- const raw = await privateFileStore(path.dirname(filePath)).readTextIfExists(path.basename(filePath));
528
- if (raw === null) return null;
529
- return safeParseProfileState(raw);
530
- } catch {
531
- return null;
532
- }
533
- }
534
- async function writeNostrProfileState(params) {
535
- const filePath = resolveNostrProfileStatePath(params.accountId, params.env);
536
- const payload = {
537
- version: PROFILE_STATE_VERSION,
538
- lastPublishedAt: params.lastPublishedAt,
539
- lastPublishedEventId: params.lastPublishedEventId,
540
- lastPublishResults: params.lastPublishResults
541
- };
542
- await privateFileStore(path.dirname(filePath)).writeJson(path.basename(filePath), payload, { trailingNewline: true });
543
- }
544
- //#endregion
545
- //#region extensions/nostr/src/seen-tracker.ts
546
- /**
547
- * Create a new seen tracker with LRU eviction and TTL expiration.
548
- */
549
- function createSeenTracker(options) {
550
- const maxEntries = options?.maxEntries ?? 1e5;
551
- const ttlMs = options?.ttlMs ?? 3600 * 1e3;
552
- const pruneIntervalMs = options?.pruneIntervalMs ?? 600 * 1e3;
553
- const entries = /* @__PURE__ */ new Map();
554
- let head = null;
555
- let tail = null;
556
- function moveToFront(id) {
557
- const entry = entries.get(id);
558
- if (!entry) return;
559
- if (head === id) return;
560
- if (entry.prev) {
561
- const prevEntry = entries.get(entry.prev);
562
- if (prevEntry) prevEntry.next = entry.next;
563
- }
564
- if (entry.next) {
565
- const nextEntry = entries.get(entry.next);
566
- if (nextEntry) nextEntry.prev = entry.prev;
567
- }
568
- if (tail === id) tail = entry.prev;
569
- entry.prev = null;
570
- entry.next = head;
571
- if (head) {
572
- const headEntry = entries.get(head);
573
- if (headEntry) headEntry.prev = id;
574
- }
575
- head = id;
576
- if (!tail) tail = id;
577
- }
578
- function removeFromList(id) {
579
- const entry = entries.get(id);
580
- if (!entry) return;
581
- if (entry.prev) {
582
- const prevEntry = entries.get(entry.prev);
583
- if (prevEntry) prevEntry.next = entry.next;
584
- } else head = entry.next;
585
- if (entry.next) {
586
- const nextEntry = entries.get(entry.next);
587
- if (nextEntry) nextEntry.prev = entry.prev;
588
- } else tail = entry.prev;
589
- }
590
- function evictLRU() {
591
- if (!tail) return;
592
- const idToEvict = tail;
593
- removeFromList(idToEvict);
594
- entries.delete(idToEvict);
595
- }
596
- function insertAtFront(id, seenAt) {
597
- const newEntry = {
598
- seenAt,
599
- prev: null,
600
- next: head
601
- };
602
- if (head) {
603
- const headEntry = entries.get(head);
604
- if (headEntry) headEntry.prev = id;
605
- }
606
- entries.set(id, newEntry);
607
- head = id;
608
- if (!tail) tail = id;
609
- }
610
- function pruneExpired() {
611
- const now = Date.now();
612
- const toDelete = [];
613
- for (const [id, entry] of entries) if (now - entry.seenAt > ttlMs) toDelete.push(id);
614
- for (const id of toDelete) {
615
- removeFromList(id);
616
- entries.delete(id);
617
- }
618
- }
619
- let pruneTimer;
620
- if (pruneIntervalMs > 0) {
621
- pruneTimer = setInterval(pruneExpired, pruneIntervalMs);
622
- if (pruneTimer.unref) pruneTimer.unref();
623
- }
624
- function add(id) {
625
- const now = Date.now();
626
- const existing = entries.get(id);
627
- if (existing) {
628
- existing.seenAt = now;
629
- moveToFront(id);
630
- return;
631
- }
632
- while (entries.size >= maxEntries) evictLRU();
633
- insertAtFront(id, now);
634
- }
635
- function has(id) {
636
- const entry = entries.get(id);
637
- if (!entry) {
638
- add(id);
639
- return false;
640
- }
641
- if (Date.now() - entry.seenAt > ttlMs) {
642
- removeFromList(id);
643
- entries.delete(id);
644
- add(id);
645
- return false;
646
- }
647
- entry.seenAt = Date.now();
648
- moveToFront(id);
649
- return true;
650
- }
651
- function peek(id) {
652
- const entry = entries.get(id);
653
- if (!entry) return false;
654
- if (Date.now() - entry.seenAt > ttlMs) {
655
- removeFromList(id);
656
- entries.delete(id);
657
- return false;
658
- }
659
- return true;
660
- }
661
- function deleteEntry(id) {
662
- if (entries.has(id)) {
663
- removeFromList(id);
664
- entries.delete(id);
665
- }
666
- }
667
- function clear() {
668
- entries.clear();
669
- head = null;
670
- tail = null;
671
- }
672
- function size() {
673
- return entries.size;
674
- }
675
- function stop() {
676
- if (pruneTimer) {
677
- clearInterval(pruneTimer);
678
- pruneTimer = void 0;
679
- }
680
- }
681
- function seed(ids) {
682
- const now = Date.now();
683
- for (let i = ids.length - 1; i >= 0; i--) {
684
- const id = ids[i];
685
- if (!entries.has(id) && entries.size < maxEntries) insertAtFront(id, now);
686
- }
687
- }
688
- return {
689
- has,
690
- add,
691
- peek,
692
- delete: deleteEntry,
693
- clear,
694
- size,
695
- stop,
696
- seed
697
- };
698
- }
699
- //#endregion
700
- //#region extensions/nostr/src/nostr-bus.ts
701
- const STARTUP_LOOKBACK_SEC = 120;
702
- const MAX_PERSISTED_EVENT_IDS = 5e3;
703
- const STATE_PERSIST_DEBOUNCE_MS = 5e3;
704
- const DEFAULT_INBOUND_GUARD_POLICY = createDirectDmPreCryptoGuardPolicy();
705
- const CIRCUIT_BREAKER_THRESHOLD = 5;
706
- const CIRCUIT_BREAKER_RESET_MS = 3e4;
707
- const HEALTH_WINDOW_MS = 6e4;
708
- function createFixedWindowRateLimiter(params) {
709
- const windowMs = Math.max(1, Math.floor(params.windowMs));
710
- const maxRequests = Math.max(1, Math.floor(params.maxRequests));
711
- const maxTrackedKeys = Math.max(1, Math.floor(params.maxTrackedKeys));
712
- const state = /* @__PURE__ */ new Map();
713
- const touch = (key, value) => {
714
- state.delete(key);
715
- state.set(key, value);
716
- };
717
- const prune = (nowMs) => {
718
- for (const [key, entry] of state) if (nowMs - entry.windowStartMs >= windowMs) state.delete(key);
719
- while (state.size > maxTrackedKeys) {
720
- const oldest = state.keys().next().value;
721
- if (!oldest) break;
722
- state.delete(oldest);
723
- }
724
- };
725
- return {
726
- isRateLimited: (key, nowMs = Date.now()) => {
727
- if (!key) return false;
728
- prune(nowMs);
729
- const existing = state.get(key);
730
- if (!existing || nowMs - existing.windowStartMs >= windowMs) {
731
- touch(key, {
732
- count: 1,
733
- windowStartMs: nowMs
734
- });
735
- return false;
736
- }
737
- const nextCount = existing.count + 1;
738
- touch(key, {
739
- count: nextCount,
740
- windowStartMs: existing.windowStartMs
741
- });
742
- return nextCount > maxRequests;
743
- },
744
- size: () => state.size,
745
- clear: () => state.clear()
746
- };
747
- }
748
- function createCircuitBreaker(relay, metrics, threshold = CIRCUIT_BREAKER_THRESHOLD, resetMs = CIRCUIT_BREAKER_RESET_MS) {
749
- const state = {
750
- state: "closed",
751
- failures: 0,
752
- lastFailure: 0,
753
- lastSuccess: Date.now()
754
- };
755
- return {
756
- canAttempt() {
757
- if (state.state === "closed") return true;
758
- if (state.state === "open") {
759
- if (Date.now() - state.lastFailure >= resetMs) {
760
- state.state = "half_open";
761
- metrics.emit("relay.circuit_breaker.half_open", 1, { relay });
762
- return true;
763
- }
764
- return false;
765
- }
766
- return true;
767
- },
768
- recordSuccess() {
769
- if (state.state === "half_open") {
770
- state.state = "closed";
771
- state.failures = 0;
772
- metrics.emit("relay.circuit_breaker.close", 1, { relay });
773
- } else if (state.state === "closed") state.failures = 0;
774
- state.lastSuccess = Date.now();
775
- },
776
- recordFailure() {
777
- state.failures++;
778
- state.lastFailure = Date.now();
779
- if (state.state === "half_open") {
780
- state.state = "open";
781
- metrics.emit("relay.circuit_breaker.open", 1, { relay });
782
- } else if (state.state === "closed" && state.failures >= threshold) {
783
- state.state = "open";
784
- metrics.emit("relay.circuit_breaker.open", 1, { relay });
785
- }
786
- },
787
- getState() {
788
- return state.state;
789
- }
790
- };
791
- }
792
- function createRelayHealthTracker() {
793
- const stats = /* @__PURE__ */ new Map();
794
- function getOrCreate(relay) {
795
- let s = stats.get(relay);
796
- if (!s) {
797
- s = {
798
- successCount: 0,
799
- failureCount: 0,
800
- latencySum: 0,
801
- latencyCount: 0,
802
- lastSuccess: 0,
803
- lastFailure: 0
804
- };
805
- stats.set(relay, s);
806
- }
807
- return s;
808
- }
809
- return {
810
- recordSuccess(relay, latencyMs) {
811
- const s = getOrCreate(relay);
812
- s.successCount++;
813
- s.latencySum += latencyMs;
814
- s.latencyCount++;
815
- s.lastSuccess = Date.now();
816
- },
817
- recordFailure(relay) {
818
- const s = getOrCreate(relay);
819
- s.failureCount++;
820
- s.lastFailure = Date.now();
821
- },
822
- getScore(relay) {
823
- const s = stats.get(relay);
824
- if (!s) return .5;
825
- const total = s.successCount + s.failureCount;
826
- if (total === 0) return .5;
827
- const successRate = s.successCount / total;
828
- const now = Date.now();
829
- const recencyBonus = s.lastSuccess > s.lastFailure ? Math.max(0, 1 - (now - s.lastSuccess) / HEALTH_WINDOW_MS) * .2 : 0;
830
- const avgLatency = s.latencyCount > 0 ? s.latencySum / s.latencyCount : 1e3;
831
- const latencyPenalty = Math.min(.2, avgLatency / 1e4);
832
- return Math.max(0, Math.min(1, successRate + recencyBonus - latencyPenalty));
833
- },
834
- getSortedRelays(relays) {
835
- return [...relays].toSorted((a, b) => this.getScore(b) - this.getScore(a));
836
- }
837
- };
838
- }
839
- /**
840
- * Start the Nostr DM bus - subscribes to NIP-04 encrypted DMs
841
- */
842
- async function startNostrBus(options) {
843
- const { privateKey, relays = DEFAULT_RELAYS, onMessage, authorizeSender, onError, onEose, onMetric, maxSeenEntries = 1e5, seenTtlMs = 3600 * 1e3 } = options;
844
- const sk = validatePrivateKey(privateKey);
845
- const pk = getPublicKey(sk);
846
- const pool = new SimplePool();
847
- const accountId = options.accountId ?? pk.slice(0, 16);
848
- const gatewayStartedAt = Math.floor(Date.now() / 1e3);
849
- const guardPolicy = createDirectDmPreCryptoGuardPolicy({
850
- ...DEFAULT_INBOUND_GUARD_POLICY,
851
- ...options.guardPolicy,
852
- rateLimit: {
853
- ...DEFAULT_INBOUND_GUARD_POLICY.rateLimit,
854
- ...options.guardPolicy?.rateLimit
855
- }
856
- });
857
- const metrics = onMetric ? createMetrics(onMetric) : createNoopMetrics();
858
- const seen = createSeenTracker({
859
- maxEntries: maxSeenEntries,
860
- ttlMs: seenTtlMs
861
- });
862
- const circuitBreakers = /* @__PURE__ */ new Map();
863
- const healthTracker = createRelayHealthTracker();
864
- for (const relay of relays) circuitBreakers.set(relay, createCircuitBreaker(relay, metrics));
865
- const state = await readNostrBusState({ accountId });
866
- const baseSince = computeSinceTimestamp(state, gatewayStartedAt);
867
- const since = Math.max(0, baseSince - STARTUP_LOOKBACK_SEC);
868
- if (state?.recentEventIds?.length) seen.seed(state.recentEventIds);
869
- await writeNostrBusState({
870
- accountId,
871
- lastProcessedAt: state?.lastProcessedAt ?? gatewayStartedAt,
872
- gatewayStartedAt,
873
- recentEventIds: state?.recentEventIds ?? []
874
- });
875
- let pendingWrite;
876
- let lastProcessedAt = state?.lastProcessedAt ?? gatewayStartedAt;
877
- let recentEventIds = (state?.recentEventIds ?? []).slice(-5e3);
878
- function scheduleStatePersist(eventCreatedAt, eventId) {
879
- lastProcessedAt = Math.max(lastProcessedAt, eventCreatedAt);
880
- recentEventIds.push(eventId);
881
- if (recentEventIds.length > MAX_PERSISTED_EVENT_IDS) recentEventIds = recentEventIds.slice(-5e3);
882
- if (pendingWrite) clearTimeout(pendingWrite);
883
- pendingWrite = setTimeout(() => {
884
- writeNostrBusState({
885
- accountId,
886
- lastProcessedAt,
887
- gatewayStartedAt,
888
- recentEventIds
889
- }).catch((err) => onError?.(err, "persist state"));
890
- }, STATE_PERSIST_DEBOUNCE_MS);
891
- }
892
- const inflight = /* @__PURE__ */ new Set();
893
- const perSenderRateLimiter = createFixedWindowRateLimiter({
894
- windowMs: guardPolicy.rateLimit.windowMs,
895
- maxRequests: guardPolicy.rateLimit.maxPerSenderPerWindow,
896
- maxTrackedKeys: guardPolicy.rateLimit.maxTrackedSenderKeys
897
- });
898
- const globalRateLimiter = createFixedWindowRateLimiter({
899
- windowMs: guardPolicy.rateLimit.windowMs,
900
- maxRequests: guardPolicy.rateLimit.maxGlobalPerWindow,
901
- maxTrackedKeys: 1
902
- });
903
- const updateRateLimiterSizeMetric = () => {
904
- metrics.emit("memory.rate_limiter_entries", perSenderRateLimiter.size() + globalRateLimiter.size());
905
- };
906
- async function handleEvent(event) {
907
- try {
908
- metrics.emit("event.received");
909
- if (seen.peek(event.id) || inflight.has(event.id)) {
910
- metrics.emit("event.duplicate");
911
- return;
912
- }
913
- inflight.add(event.id);
914
- const markSeen = () => {
915
- seen.add(event.id);
916
- metrics.emit("memory.seen_tracker_size", seen.size());
917
- };
918
- const rejectAndMarkSeen = (metric) => {
919
- markSeen();
920
- metrics.emit(metric);
921
- };
922
- if (event.pubkey === pk) {
923
- rejectAndMarkSeen("event.rejected.self_message");
924
- return;
925
- }
926
- if (event.created_at < since) {
927
- rejectAndMarkSeen("event.rejected.stale");
928
- return;
929
- }
930
- if (event.created_at > Math.floor(Date.now() / 1e3) + guardPolicy.maxFutureSkewSec) {
931
- metrics.emit("event.rejected.future");
932
- return;
933
- }
934
- if (!guardPolicy.allowedKinds.includes(event.kind)) {
935
- rejectAndMarkSeen("event.rejected.wrong_kind");
936
- return;
937
- }
938
- let targetsUs = false;
939
- for (const t of event.tags) if (t[0] === "p" && t[1] === pk) {
940
- targetsUs = true;
941
- break;
942
- }
943
- if (!targetsUs) {
944
- rejectAndMarkSeen("event.rejected.wrong_kind");
945
- return;
946
- }
947
- const replyTo = async (text) => {
948
- await sendEncryptedDm(pool, sk, event.pubkey, text, relays, metrics, circuitBreakers, healthTracker, onError);
949
- };
950
- const rejectIfGlobalRateLimited = () => {
951
- updateRateLimiterSizeMetric();
952
- if (globalRateLimiter.isRateLimited("global")) {
953
- metrics.emit("rate_limit.global");
954
- metrics.emit("event.rejected.rate_limited");
955
- updateRateLimiterSizeMetric();
956
- return true;
957
- }
958
- updateRateLimiterSizeMetric();
959
- return false;
960
- };
961
- const rejectIfVerifiedSenderRateLimited = () => {
962
- updateRateLimiterSizeMetric();
963
- if (perSenderRateLimiter.isRateLimited(event.pubkey)) {
964
- metrics.emit("rate_limit.per_sender");
965
- metrics.emit("event.rejected.rate_limited");
966
- updateRateLimiterSizeMetric();
967
- return true;
968
- }
969
- updateRateLimiterSizeMetric();
970
- return false;
971
- };
972
- if (Buffer.byteLength(event.content, "utf8") > guardPolicy.maxCiphertextBytes) {
973
- if (rejectIfGlobalRateLimited()) return;
974
- rejectAndMarkSeen("event.rejected.oversized_ciphertext");
975
- return;
976
- }
977
- if (rejectIfGlobalRateLimited()) return;
978
- if (!verifyEvent(event)) {
979
- rejectAndMarkSeen("event.rejected.invalid_signature");
980
- onError?.(/* @__PURE__ */ new Error("Invalid signature"), `event ${event.id}`);
981
- return;
982
- }
983
- if (rejectIfVerifiedSenderRateLimited()) return;
984
- if (authorizeSender) {
985
- if (await authorizeSender({
986
- senderPubkey: event.pubkey,
987
- reply: replyTo
988
- }) !== "allow") {
989
- markSeen();
990
- return;
991
- }
992
- }
993
- let plaintext;
994
- try {
995
- plaintext = decrypt(sk, event.pubkey, event.content);
996
- metrics.emit("decrypt.success");
997
- } catch (err) {
998
- markSeen();
999
- metrics.emit("decrypt.failure");
1000
- metrics.emit("event.rejected.decrypt_failed");
1001
- onError?.(err, `decrypt from ${event.pubkey}`);
1002
- return;
1003
- }
1004
- if (Buffer.byteLength(plaintext, "utf8") > guardPolicy.maxPlaintextBytes) {
1005
- markSeen();
1006
- metrics.emit("event.rejected.oversized_plaintext");
1007
- return;
1008
- }
1009
- await onMessage(event.pubkey, plaintext, replyTo, {
1010
- eventId: event.id,
1011
- createdAt: event.created_at
1012
- });
1013
- markSeen();
1014
- metrics.emit("event.processed");
1015
- scheduleStatePersist(event.created_at, event.id);
1016
- } catch (err) {
1017
- onError?.(err, `event ${event.id}`);
1018
- } finally {
1019
- inflight.delete(event.id);
1020
- }
1021
- }
1022
- const sub = pool.subscribeMany(relays, [{
1023
- kinds: [4],
1024
- "#p": [pk],
1025
- since
1026
- }], {
1027
- onevent: handleEvent,
1028
- oneose: () => {
1029
- for (const relay of relays) metrics.emit("relay.message.eose", 1, { relay });
1030
- onEose?.(relays.join(", "));
1031
- },
1032
- onclose: (reason) => {
1033
- for (const relay of relays) {
1034
- metrics.emit("relay.message.closed", 1, { relay });
1035
- options.onDisconnect?.(relay);
1036
- }
1037
- onError?.(/* @__PURE__ */ new Error(`Subscription closed: ${reason.join(", ")}`), "subscription");
1038
- }
1039
- });
1040
- const sendDm = async (toPubkey, text) => {
1041
- await sendEncryptedDm(pool, sk, toPubkey, text, relays, metrics, circuitBreakers, healthTracker, onError);
1042
- };
1043
- const publishProfile$1 = async (profile) => {
1044
- const result = await publishProfile(pool, sk, relays, profile, (await readNostrProfileState({ accountId }))?.lastPublishedAt ?? void 0);
1045
- const publishResults = {};
1046
- for (const relay of result.successes) publishResults[relay] = "ok";
1047
- for (const { relay, error } of result.failures) publishResults[relay] = error === "timeout" ? "timeout" : "failed";
1048
- await writeNostrProfileState({
1049
- accountId,
1050
- lastPublishedAt: result.createdAt,
1051
- lastPublishedEventId: result.eventId,
1052
- lastPublishResults: publishResults
1053
- });
1054
- return result;
1055
- };
1056
- const getProfileState = async () => {
1057
- const state = await readNostrProfileState({ accountId });
1058
- return {
1059
- lastPublishedAt: state?.lastPublishedAt ?? null,
1060
- lastPublishedEventId: state?.lastPublishedEventId ?? null,
1061
- lastPublishResults: state?.lastPublishResults ?? null
1062
- };
1063
- };
1064
- return {
1065
- close: () => {
1066
- sub.close();
1067
- seen.stop();
1068
- perSenderRateLimiter.clear();
1069
- globalRateLimiter.clear();
1070
- if (pendingWrite) {
1071
- clearTimeout(pendingWrite);
1072
- writeNostrBusState({
1073
- accountId,
1074
- lastProcessedAt,
1075
- gatewayStartedAt,
1076
- recentEventIds
1077
- }).catch((err) => onError?.(err, "persist state on close"));
1078
- }
1079
- },
1080
- publicKey: pk,
1081
- sendDm,
1082
- getMetrics: () => metrics.getSnapshot(),
1083
- publishProfile: publishProfile$1,
1084
- getProfileState
1085
- };
1086
- }
1087
- /**
1088
- * Send an encrypted DM to a pubkey
1089
- */
1090
- async function sendEncryptedDm(pool, sk, toPubkey, text, relays, metrics, circuitBreakers, healthTracker, onError) {
1091
- const reply = finalizeEvent({
1092
- kind: 4,
1093
- content: encrypt(sk, toPubkey, text),
1094
- tags: [["p", toPubkey]],
1095
- created_at: Math.floor(Date.now() / 1e3)
1096
- }, sk);
1097
- const sortedRelays = healthTracker.getSortedRelays(relays);
1098
- let lastError;
1099
- for (const relay of sortedRelays) {
1100
- const cb = circuitBreakers.get(relay);
1101
- if (cb && !cb.canAttempt()) continue;
1102
- const startTime = Date.now();
1103
- try {
1104
- const [publishPromise] = pool.publish([relay], reply);
1105
- if (!publishPromise) throw new Error(`Failed to create publish promise for relay ${relay}`);
1106
- await publishPromise;
1107
- const latency = Date.now() - startTime;
1108
- cb?.recordSuccess();
1109
- healthTracker.recordSuccess(relay, latency);
1110
- return;
1111
- } catch (err) {
1112
- lastError = err;
1113
- const latency = Date.now() - startTime;
1114
- cb?.recordFailure();
1115
- healthTracker.recordFailure(relay);
1116
- metrics.emit("relay.error", 1, {
1117
- relay,
1118
- latency
1119
- });
1120
- onError?.(lastError, `publish to ${relay}`);
1121
- }
1122
- }
1123
- throw new Error(`Failed to publish to any relay: ${lastError?.message}`);
1124
- }
1125
- //#endregion
1126
- //#region extensions/nostr/src/gateway.ts
1127
- const activeBuses = /* @__PURE__ */ new Map();
1128
- const metricsSnapshots = /* @__PURE__ */ new Map();
1129
- const ACCESS_GROUP_PREFIX = "accessGroup:";
1130
- function parseNostrAccessGroupAllowFromEntry(entry) {
1131
- const trimmed = entry.trim();
1132
- if (!trimmed.startsWith(ACCESS_GROUP_PREFIX)) return null;
1133
- return trimmed.slice(12).trim() || null;
1134
- }
1135
- function normalizeNostrAllowEntry(entry) {
1136
- const trimmed = entry.trim();
1137
- if (!trimmed) return null;
1138
- if (trimmed === "*") return "*";
1139
- const accessGroup = parseNostrAccessGroupAllowFromEntry(trimmed);
1140
- if (accessGroup) return `accessGroup:${accessGroup}`;
1141
- try {
1142
- return normalizePubkey(trimmed.replace(/^nostr:/i, ""));
1143
- } catch {
1144
- return null;
1145
- }
1146
- }
1147
- function normalizeNostrSenderPubkey(value) {
1148
- try {
1149
- return normalizePubkey(value);
1150
- } catch {
1151
- return null;
1152
- }
1153
- }
1154
- const nostrIngressIdentity = {
1155
- key: "nostr-pubkey",
1156
- normalizeEntry: normalizeNostrAllowEntry,
1157
- normalizeSubject: normalizeNostrSenderPubkey,
1158
- sensitivity: "pii",
1159
- entryIdPrefix: "nostr-entry"
1160
- };
1161
- const startNostrGatewayAccount = async (ctx) => {
1162
- const account = ctx.account;
1163
- ctx.setStatus({
1164
- accountId: account.accountId,
1165
- publicKey: account.publicKey
1166
- });
1167
- ctx.log?.info?.(`[${account.accountId}] starting Nostr provider (pubkey: ${account.publicKey})`);
1168
- if (!account.configured) throw new Error("Nostr private key not configured");
1169
- const runtime = getNostrRuntime();
1170
- const pairing = createChannelPairingController({
1171
- core: runtime,
1172
- channel: "nostr",
1173
- accountId: account.accountId
1174
- });
1175
- const resolveInboundAccess = async (senderPubkey, rawBody) => await resolveStableChannelMessageIngress({
1176
- channelId: "nostr",
1177
- accountId: account.accountId,
1178
- identity: nostrIngressIdentity,
1179
- cfg: ctx.cfg,
1180
- useDefaultPairingStore: true,
1181
- subject: { stableId: senderPubkey },
1182
- conversation: {
1183
- kind: "direct",
1184
- id: senderPubkey
1185
- },
1186
- dmPolicy: account.config.dmPolicy ?? "pairing",
1187
- allowFrom: account.config.allowFrom,
1188
- command: runtime.channel.commands.shouldComputeCommandAuthorized(rawBody, ctx.cfg) ? { modeWhenAccessGroupsOff: "configured" } : void 0
1189
- });
1190
- let busHandle = null;
1191
- const authorizeSender = async (input) => {
1192
- const resolved = await resolveInboundAccess(input.senderId, "");
1193
- if (resolved.senderAccess.decision === "allow") return "allow";
1194
- if (resolved.senderAccess.decision === "pairing") {
1195
- await pairing.issueChallenge({
1196
- senderId: input.senderId,
1197
- senderIdLine: `Your Nostr pubkey: ${input.senderId}`,
1198
- sendPairingReply: input.reply,
1199
- onCreated: () => {
1200
- ctx.log?.debug?.(`[${account.accountId}] nostr pairing request sender=${input.senderId}`);
1201
- },
1202
- onReplyError: (err) => {
1203
- ctx.log?.warn?.(`[${account.accountId}] nostr pairing reply failed for ${input.senderId}: ${String(err)}`);
1204
- }
1205
- });
1206
- return "pairing";
1207
- }
1208
- ctx.log?.debug?.(`[${account.accountId}] blocked Nostr sender ${input.senderId} (${resolved.senderAccess.reasonCode})`);
1209
- return "block";
1210
- };
1211
- const bus = await startNostrBus({
1212
- accountId: account.accountId,
1213
- privateKey: account.privateKey,
1214
- relays: account.relays,
1215
- authorizeSender: async ({ senderPubkey, reply }) => await authorizeSender({
1216
- senderId: senderPubkey,
1217
- reply
1218
- }),
1219
- onMessage: async (senderPubkey, text, reply, meta) => {
1220
- const resolvedAccess = await resolveInboundAccess(senderPubkey, text);
1221
- if (resolvedAccess.senderAccess.decision !== "allow") {
1222
- ctx.log?.warn?.(`[${account.accountId}] dropping Nostr DM after preflight drift (${senderPubkey}, ${resolvedAccess.senderAccess.reasonCode})`);
1223
- return;
1224
- }
1225
- const { dispatchInboundDirectDmWithRuntime } = await import("./inbound-direct-dm-runtime-DwiDXi8L.js");
1226
- await dispatchInboundDirectDmWithRuntime({
1227
- cfg: ctx.cfg,
1228
- runtime,
1229
- channel: "nostr",
1230
- channelLabel: "Nostr",
1231
- accountId: account.accountId,
1232
- peer: {
1233
- kind: "direct",
1234
- id: senderPubkey
1235
- },
1236
- senderId: senderPubkey,
1237
- senderAddress: `nostr:${senderPubkey}`,
1238
- recipientAddress: `nostr:${account.publicKey}`,
1239
- conversationLabel: senderPubkey,
1240
- rawBody: text,
1241
- messageId: meta.eventId,
1242
- timestamp: meta.createdAt * 1e3,
1243
- commandAuthorized: resolvedAccess.commandAccess.requested ? resolvedAccess.commandAccess.authorized : void 0,
1244
- deliver: async (payload) => {
1245
- const outboundText = payload && typeof payload === "object" && "text" in payload ? payload.text ?? "" : "";
1246
- if (!outboundText.trim()) return;
1247
- const tableMode = runtime.channel.text.resolveMarkdownTableMode({
1248
- cfg: ctx.cfg,
1249
- channel: "nostr",
1250
- accountId: account.accountId
1251
- });
1252
- await reply(runtime.channel.text.convertMarkdownTables(outboundText, tableMode));
1253
- },
1254
- onRecordError: (err) => {
1255
- ctx.log?.error?.(`[${account.accountId}] failed recording Nostr inbound session: ${String(err)}`);
1256
- },
1257
- onDispatchError: (err, info) => {
1258
- ctx.log?.error?.(`[${account.accountId}] Nostr ${info.kind} reply failed: ${String(err)}`);
1259
- }
1260
- });
1261
- },
1262
- onError: (error, context) => {
1263
- ctx.log?.error?.(`[${account.accountId}] Nostr error (${context}): ${error.message}`);
1264
- },
1265
- onConnect: (relay) => {
1266
- ctx.log?.debug?.(`[${account.accountId}] Connected to relay: ${relay}`);
1267
- },
1268
- onDisconnect: (relay) => {
1269
- ctx.log?.debug?.(`[${account.accountId}] Disconnected from relay: ${relay}`);
1270
- },
1271
- onEose: (relays) => {
1272
- ctx.log?.debug?.(`[${account.accountId}] EOSE received from relays: ${relays}`);
1273
- },
1274
- onMetric: (event) => {
1275
- if (event.name.startsWith("event.rejected.")) ctx.log?.debug?.(`[${account.accountId}] Metric: ${event.name} ${JSON.stringify(event.labels)}`);
1276
- else if (event.name === "relay.circuit_breaker.open") ctx.log?.warn?.(`[${account.accountId}] Circuit breaker opened for relay: ${event.labels?.relay}`);
1277
- else if (event.name === "relay.circuit_breaker.close") ctx.log?.info?.(`[${account.accountId}] Circuit breaker closed for relay: ${event.labels?.relay}`);
1278
- else if (event.name === "relay.error") ctx.log?.debug?.(`[${account.accountId}] Relay error: ${event.labels?.relay}`);
1279
- if (busHandle) metricsSnapshots.set(account.accountId, busHandle.getMetrics());
1280
- }
1281
- });
1282
- busHandle = bus;
1283
- activeBuses.set(account.accountId, bus);
1284
- ctx.log?.info?.(`[${account.accountId}] Nostr provider started, connected to ${account.relays.length} relay(s)`);
1285
- return { stop: () => {
1286
- bus.close();
1287
- activeBuses.delete(account.accountId);
1288
- metricsSnapshots.delete(account.accountId);
1289
- ctx.log?.info?.(`[${account.accountId}] Nostr provider stopped`);
1290
- } };
1291
- };
1292
- const nostrPairingTextAdapter = {
1293
- idLabel: "nostrPubkey",
1294
- message: "Your pairing request has been approved!",
1295
- normalizeAllowEntry: (entry) => {
1296
- try {
1297
- return normalizePubkey(entry.trim().replace(/^nostr:/i, ""));
1298
- } catch {
1299
- return entry.trim();
1300
- }
1301
- },
1302
- notify: async ({ cfg, id, message, accountId }) => {
1303
- const bus = activeBuses.get(accountId ?? resolveDefaultNostrAccountId(cfg));
1304
- if (bus) await bus.sendDm(id, message);
1305
- }
1306
- };
1307
- const nostrOutboundAdapter = {
1308
- deliveryMode: "direct",
1309
- textChunkLimit: 4e3,
1310
- deliveryCapabilities: { durableFinal: {
1311
- text: true,
1312
- messageSendingHooks: true
1313
- } },
1314
- sendText: async ({ cfg, to, text, accountId }) => {
1315
- const core = getNostrRuntime();
1316
- const aid = accountId ?? resolveDefaultNostrAccountId(cfg);
1317
- const bus = activeBuses.get(aid);
1318
- if (!bus) throw new Error(`Nostr bus not running for account ${aid}`);
1319
- const tableMode = core.channel.text.resolveMarkdownTableMode({
1320
- cfg,
1321
- channel: "nostr",
1322
- accountId: aid
1323
- });
1324
- const message = core.channel.text.convertMarkdownTables(text ?? "", tableMode);
1325
- const normalizedTo = normalizePubkey(to);
1326
- await bus.sendDm(normalizedTo, message);
1327
- return attachChannelToResult("nostr", {
1328
- to: normalizedTo,
1329
- messageId: `nostr-${Date.now()}`
1330
- });
1331
- }
1332
- };
1333
- function getActiveNostrBuses() {
1334
- return new Map(activeBuses);
1335
- }
1336
- //#endregion
1337
- //#region extensions/nostr/src/session-route.ts
1338
- function resolveNostrOutboundSessionRoute(params) {
1339
- const target = stripChannelTargetPrefix(params.target, "nostr");
1340
- if (!target) return null;
1341
- return buildChannelOutboundSessionRoute({
1342
- cfg: params.cfg,
1343
- agentId: params.agentId,
1344
- channel: "nostr",
1345
- accountId: params.accountId,
1346
- peer: {
1347
- kind: "direct",
1348
- id: target
1349
- },
1350
- chatType: "direct",
1351
- from: `nostr:${target}`,
1352
- to: `nostr:${target}`
1353
- });
1354
- }
1355
- //#endregion
1356
- //#region extensions/nostr/src/channel.ts
1357
- const resolveNostrDmPolicy = createScopedDmSecurityResolver({
1358
- channelKey: "nostr",
1359
- resolvePolicy: (account) => account.config.dmPolicy,
1360
- resolveAllowFrom: (account) => account.config.allowFrom,
1361
- policyPathSuffix: "dmPolicy",
1362
- defaultPolicy: "pairing",
1363
- approveHint: formatPairingApproveHint("nostr"),
1364
- normalizeEntry: (raw) => {
1365
- try {
1366
- return normalizePubkey(raw.trim().replace(/^nostr:/i, ""));
1367
- } catch {
1368
- return raw.trim();
1369
- }
1370
- }
1371
- });
1372
- const nostrConfigAdapter = createTopLevelChannelConfigAdapter({
1373
- sectionKey: "nostr",
1374
- resolveAccount: (cfg) => resolveNostrAccount({ cfg }),
1375
- listAccountIds: listNostrAccountIds,
1376
- defaultAccountId: resolveDefaultNostrAccountId,
1377
- deleteMode: "clear-fields",
1378
- clearBaseFields: [
1379
- "name",
1380
- "defaultAccount",
1381
- "privateKey",
1382
- "relays",
1383
- "dmPolicy",
1384
- "allowFrom",
1385
- "profile"
1386
- ],
1387
- resolveAllowFrom: (account) => account.config.allowFrom,
1388
- formatAllowFrom: (allowFrom) => allowFrom.map((entry) => String(entry).trim()).filter(Boolean).map((entry) => {
1389
- if (entry === "*") return "*";
1390
- try {
1391
- return normalizePubkey(entry);
1392
- } catch {
1393
- return entry;
1394
- }
1395
- }).filter(Boolean)
1396
- });
1397
- const nostrMessageAdapter = createChannelMessageAdapterFromOutbound({
1398
- id: "nostr",
1399
- outbound: nostrOutboundAdapter
1400
- });
1401
- const nostrPlugin = createChatChannelPlugin({
1402
- base: {
1403
- id: "nostr",
1404
- meta: {
1405
- id: "nostr",
1406
- label: "Nostr",
1407
- selectionLabel: "Nostr",
1408
- docsPath: "/channels/nostr",
1409
- docsLabel: "nostr",
1410
- blurb: "Decentralized DMs via Nostr relays (NIP-04)",
1411
- order: 100
1412
- },
1413
- capabilities: {
1414
- chatTypes: ["direct"],
1415
- media: false
1416
- },
1417
- reload: { configPrefixes: ["channels.nostr"] },
1418
- configSchema: buildChannelConfigSchema(NostrConfigSchema),
1419
- setup: nostrSetupAdapter,
1420
- setupWizard: nostrSetupWizard,
1421
- config: {
1422
- ...nostrConfigAdapter,
1423
- isConfigured: (account) => account.configured,
1424
- describeAccount: (account) => describeAccountSnapshot({
1425
- account,
1426
- configured: account.configured,
1427
- extra: { publicKey: account.publicKey }
1428
- })
1429
- },
1430
- messaging: {
1431
- targetPrefixes: ["nostr"],
1432
- normalizeTarget: (target) => {
1433
- const cleaned = target.trim().replace(/^nostr:/i, "");
1434
- try {
1435
- return normalizePubkey(cleaned);
1436
- } catch {
1437
- return cleaned;
1438
- }
1439
- },
1440
- targetResolver: {
1441
- looksLikeId: (input) => {
1442
- const trimmed = input.trim();
1443
- return trimmed.startsWith("npub1") || /^[0-9a-fA-F]{64}$/.test(trimmed);
1444
- },
1445
- hint: "<npub|hex pubkey|nostr:npub...>"
1446
- },
1447
- resolveOutboundSessionRoute: (params) => resolveNostrOutboundSessionRoute(params)
1448
- },
1449
- message: nostrMessageAdapter,
1450
- status: { ...createComputedAccountStatusAdapter({
1451
- defaultRuntime: createDefaultChannelRuntimeState(DEFAULT_ACCOUNT_ID),
1452
- collectStatusIssues: (accounts) => collectStatusIssuesFromLastError("nostr", accounts),
1453
- buildChannelSummary: ({ snapshot }) => buildPassiveChannelStatusSummary(snapshot, { publicKey: snapshot.publicKey ?? null }),
1454
- resolveAccountSnapshot: ({ account, runtime }) => ({
1455
- accountId: account.accountId,
1456
- name: account.name,
1457
- enabled: account.enabled,
1458
- configured: account.configured,
1459
- extra: {
1460
- publicKey: account.publicKey,
1461
- profile: account.profile,
1462
- ...buildTrafficStatusSummary(runtime)
1463
- }
1464
- })
1465
- }) },
1466
- gateway: { startAccount: startNostrGatewayAccount }
1467
- },
1468
- pairing: { text: nostrPairingTextAdapter },
1469
- security: { resolveDmPolicy: resolveNostrDmPolicy },
1470
- outbound: nostrOutboundAdapter
1471
- });
1472
- /**
1473
- * Publish a profile (kind:0) for a Nostr account.
1474
- * @param accountId - Account ID (defaults to "default")
1475
- * @param profile - Profile data to publish
1476
- * @returns Publish results with successes and failures
1477
- * @throws Error if account is not running
1478
- */
1479
- async function publishNostrProfile(accountId, profile) {
1480
- const resolvedAccountId = accountId ?? "default";
1481
- const bus = getActiveNostrBuses().get(resolvedAccountId);
1482
- if (!bus) throw new Error(`Nostr bus not running for account ${resolvedAccountId}`);
1483
- return bus.publishProfile(profile);
1484
- }
1485
- /**
1486
- * Get profile publish state for a Nostr account.
1487
- * @param accountId - Account ID (defaults to "default")
1488
- * @returns Profile publish state or null if account not running
1489
- */
1490
- async function getNostrProfileState(accountId = DEFAULT_ACCOUNT_ID) {
1491
- const bus = getActiveNostrBuses().get(accountId);
1492
- if (!bus) return null;
1493
- return bus.getProfileState();
1494
- }
1495
- //#endregion
1496
- export { setNostrRuntime as a, getNostrRuntime as i, nostrPlugin as n, contentToProfile as o, publishNostrProfile as r, getNostrProfileState as t };