@spacebar_ai/moldclaw-core 2026.3.41 → 2026.3.44

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 (1144) hide show
  1. package/dist/accounts-5qY-dKca.d.ts +103 -0
  2. package/dist/accounts-SqdHz2ZP.js +114 -0
  3. package/dist/acp-cli-E6bcNqiE.js +2093 -0
  4. package/dist/actions.runtime-BU_XMuLk.js +119 -0
  5. package/dist/actions.runtime-CY5h8lqH.js +133 -0
  6. package/dist/agent-scope-lZlwP1At.js +208 -0
  7. package/dist/agents-C4SkadR1.js +853 -0
  8. package/dist/agents-RfwqGCzE.js +222 -0
  9. package/dist/agents.config-CX9CPNfP.js +17 -0
  10. package/dist/agents.config-DF9Zwn9n.js +121 -0
  11. package/dist/allow-list-3WSjz1zl.js +81 -0
  12. package/dist/allowlist-DNbDjFjw.js +142 -0
  13. package/dist/api-BEOpJ7dR.js +117 -0
  14. package/dist/audit-CpJz_eu6.js +787 -0
  15. package/dist/audit-CpfSjvyo.js +54 -0
  16. package/dist/audit-channel.collect.runtime-BeGotloZ.js +605 -0
  17. package/dist/audit-channel.runtime-BJDZ7ETt.js +121 -0
  18. package/dist/audit-extra.async-C2G0mqmk.js +813 -0
  19. package/dist/audit-membership-runtime-B1FqJsPV.js +162 -0
  20. package/dist/audit.deep.runtime-DyL9O_sU.js +25 -0
  21. package/dist/audit.nondeep.runtime-C6jFgJfH.js +832 -0
  22. package/dist/audit.runtime-Dnlsn23e.js +118 -0
  23. package/dist/auth-Ch3Rchm4.js +101 -0
  24. package/dist/auth-choice-CEFSlnLT.js +122 -0
  25. package/dist/auth-choice-CVCef-eU.js +268 -0
  26. package/dist/auth-choice-Cez-pXrg.js +507 -0
  27. package/dist/auth-choice-options-DO78mvPe.js +123 -0
  28. package/dist/auth-choice-prompt-CUkC7Mmb.js +36 -0
  29. package/dist/auth-choice-prompt-DCuQRiVl.js +115 -0
  30. package/dist/auth-choice.apply-helpers-BhbNIV8X.js +66 -0
  31. package/dist/auth-choice.plugin-providers.runtime-4BhqvEw_.js +119 -0
  32. package/dist/auth-profiles-smABVXzp.js +128040 -0
  33. package/dist/auth-profiles.runtime-Cr-ojtTc.js +116 -0
  34. package/dist/banner-CojBHPWr.js +342 -0
  35. package/dist/bluebubbles-BnLsj2Fy.d.ts +6 -0
  36. package/dist/bluebubbles-CVk7M3Bl.js +64 -0
  37. package/dist/bot-DdyrB2z9.d.ts +478 -0
  38. package/dist/brave-w4Fo8WZ3.js +24 -0
  39. package/dist/browser-cli-DWFs3P_i.js +1494 -0
  40. package/dist/build-info.json +3 -3
  41. package/dist/bundled/boot-md/handler.d.ts +1 -1
  42. package/dist/bundled/boot-md/handler.js +35 -35
  43. package/dist/bundled/bootstrap-extra-files/handler.d.ts +1 -1
  44. package/dist/bundled/bootstrap-extra-files/handler.js +1 -1
  45. package/dist/bundled/command-logger/handler.d.ts +1 -1
  46. package/dist/bundled/session-memory/handler.d.ts +1 -1
  47. package/dist/bundled/session-memory/handler.js +36 -36
  48. package/dist/call-Do7wTSr7.js +39 -0
  49. package/dist/call-gdDAt07d.js +640 -0
  50. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  51. package/dist/channel-B26pkce0.js +214 -0
  52. package/dist/channel-BJHp0AQC.js +352 -0
  53. package/dist/channel-BKFOv51P.js +4681 -0
  54. package/dist/channel-BNgpOY8v.js +538 -0
  55. package/dist/channel-BcQAAo2P.js +226 -0
  56. package/dist/channel-BvNdnhbx.js +1598 -0
  57. package/dist/channel-C1Rda3Jd.js +306 -0
  58. package/dist/channel-C87DG-F7.js +803 -0
  59. package/dist/channel-CIip0kvZ.js +619 -0
  60. package/dist/channel-CTPxoT_E2.js +316 -0
  61. package/dist/channel-CklaCzUG.js +562 -0
  62. package/dist/channel-CoJnAdLs.js +920 -0
  63. package/dist/channel-D3tafL1_.js +949 -0
  64. package/dist/channel-DFMrP2uu.js +542 -0
  65. package/dist/channel-DMd5cJQe.js +397 -0
  66. package/dist/channel-Dm34kxAJ.js +207 -0
  67. package/dist/channel-DmwF9udn.js +1321 -0
  68. package/dist/channel-account-context-Bjur9nlh.js +103 -0
  69. package/dist/channel-bGnST659.js +943 -0
  70. package/dist/channel-hIgbkTZf.js +575 -0
  71. package/dist/channel-m_TGrDKo.js +497 -0
  72. package/dist/channel-options-DoUPBMa8.js +50 -0
  73. package/dist/channel-plugin-ids-TZIY4hFs.js +26 -0
  74. package/dist/channel-summary-qD54bOBO.js +111 -0
  75. package/dist/channel.runtime-B0H04Dkk.js +199 -0
  76. package/dist/channel.runtime-BU1f3NkV.js +418 -0
  77. package/dist/channel.runtime-Bj1sfLep.js +4011 -0
  78. package/dist/channel.runtime-BtPAAJc3.js +870 -0
  79. package/dist/channel.runtime-Bx-10m_j.js +171 -0
  80. package/dist/channel.runtime-CI_TBywQ.js +179 -0
  81. package/dist/channel.runtime-CSLj14-Z.js +182 -0
  82. package/dist/channel.runtime-D-lTSYAd.js +404 -0
  83. package/dist/channel.runtime-DJqIOSji.js +127 -0
  84. package/dist/channel.runtime-Ec8aQ9V2.js +241 -0
  85. package/dist/channel.runtime-ax5a1jBm.js +218 -0
  86. package/dist/channel.setup-B-ncdYLT.js +9 -0
  87. package/dist/channel.setup-BY4bh5dm.js +9 -0
  88. package/dist/channel.setup-BovsdMnL.js +57 -0
  89. package/dist/channel.setup-CXzXA25h.js +6 -0
  90. package/dist/channel.setup-DcZUEufN.js +8 -0
  91. package/dist/channel.setup-E6zceRsE.js +8 -0
  92. package/dist/channel.setup-Pc7nGbdX.js +11 -0
  93. package/dist/channels/plugins/actions/discord.d.ts +2 -2
  94. package/dist/channels/plugins/actions/discord.js +35 -35
  95. package/dist/channels/plugins/actions/signal.d.ts +1 -1
  96. package/dist/channels/plugins/actions/signal.js +35 -35
  97. package/dist/channels/plugins/actions/telegram.d.ts +2 -2
  98. package/dist/channels/plugins/actions/telegram.js +35 -35
  99. package/dist/channels/plugins/agent-tools/whatsapp-login.d.ts +3 -3
  100. package/dist/channels/plugins/agent-tools/whatsapp-login.js +35 -35
  101. package/dist/channels-CPtE5ND6.js +404 -0
  102. package/dist/channels-Cj8ZolHI.js +1118 -0
  103. package/dist/channels-cli-D2sKrntt.js +291 -0
  104. package/dist/channels-status-issues-CzIHODg2.js +16 -0
  105. package/dist/clawbot-cli-BcwEDmUn.js +118 -0
  106. package/dist/cleanup-utils-D0L17RsX.js +96 -0
  107. package/dist/cli/daemon-cli.js +1 -1
  108. package/dist/cli-BvGVPKnD.js +154 -0
  109. package/dist/command-registry-CADQzTAg.js +14 -0
  110. package/dist/command-registry-ktiJNAJd.js +242 -0
  111. package/dist/command-secret-gateway-CXp10RTM.js +111 -0
  112. package/dist/compact.runtime-DyKL-Iar.js +116 -0
  113. package/dist/completion-cli-Bz4STrpt.js +17 -0
  114. package/dist/completion-cli-pVda2OFb.js +445 -0
  115. package/dist/config-BbvDRSYp.js +31 -0
  116. package/dist/config-CwBv71QC.js +44 -0
  117. package/dist/config-cli-Y0uXHbOw.js +678 -0
  118. package/dist/config-guard-BpW5g7JE.js +118 -0
  119. package/dist/config-validation-B-vLIsbo.js +262 -0
  120. package/dist/config-value-DT3-5958.js +132 -0
  121. package/dist/configure-B9U-jCqP.js +1100 -0
  122. package/dist/configure-BJ3Wrs5b.js +243 -0
  123. package/dist/control-ui-assets-C1YDYi82.js +232 -0
  124. package/dist/control-ui-shared-Dm5Dh0Lo.js +29 -0
  125. package/dist/core-BwKq3krw.js +150 -0
  126. package/dist/core-hjBwfDsW.d.ts +87 -0
  127. package/dist/cron-cli-DTDgfoMh.js +639 -0
  128. package/dist/daemon-cli-C-dkAXR1.js +339 -0
  129. package/dist/daemon-install-Oy0Q5pMF.js +180 -0
  130. package/dist/deliver-DNGnDqF9.js +111 -0
  131. package/dist/deliver-runtime-CCNZIhET.js +111 -0
  132. package/dist/device-id-cli-XvwZbIyC.js +52 -0
  133. package/dist/device-identity-IG5DngWM.js +365 -0
  134. package/dist/devices-cli-DIsxj4xp.js +342 -0
  135. package/dist/diagnostic-DTPopFvh.js +310 -0
  136. package/dist/directory-cli-DTSY3Ktr.js +311 -0
  137. package/dist/directory-config-helpers-DpFcAbmo.d.ts +38 -0
  138. package/dist/directory.static-CBRAUwUW.js +44 -0
  139. package/dist/discord-CrgxhEWw.js +114 -0
  140. package/dist/discovery-DrG7wmAR.js +48 -0
  141. package/dist/dm-policy-shared-DKoGdUpY.d.ts +95 -0
  142. package/dist/dns-cli-BJiz6CLK.js +217 -0
  143. package/dist/docs-cli-Dq2Yi5qO.js +174 -0
  144. package/dist/doctor-completion-D3GeVcFP.js +90 -0
  145. package/dist/doctor-config-flow-B1cMjr8h.js +112 -0
  146. package/dist/doctor-config-flow-BUe7JpV3.js +2437 -0
  147. package/dist/enable-Bc8bCuVe.js +24 -0
  148. package/dist/entry.js +4 -4
  149. package/dist/exec-approvals-cli-kLAev6bP.js +421 -0
  150. package/dist/extensions/acpx/index.d.ts +1 -1
  151. package/dist/extensions/amazon-bedrock/index.d.ts +1 -1
  152. package/dist/extensions/amazon-bedrock/index.js +4 -4
  153. package/dist/extensions/anthropic/index.d.ts +1 -1
  154. package/dist/extensions/anthropic/index.js +35 -35
  155. package/dist/extensions/bluebubbles/index.d.ts +1 -1
  156. package/dist/extensions/bluebubbles/index.js +39 -39
  157. package/dist/extensions/bluebubbles/setup-entry.d.ts +2 -2
  158. package/dist/extensions/bluebubbles/setup-entry.js +39 -39
  159. package/dist/extensions/brave/index.d.ts +1 -1
  160. package/dist/extensions/brave/index.js +5 -5
  161. package/dist/extensions/byteplus/index.d.ts +1 -1
  162. package/dist/extensions/byteplus/index.js +35 -35
  163. package/dist/extensions/cloudflare-ai-gateway/index.d.ts +1 -1
  164. package/dist/extensions/cloudflare-ai-gateway/index.js +36 -36
  165. package/dist/extensions/copilot-proxy/index.d.ts +1 -1
  166. package/dist/extensions/copilot-proxy/index.js +4 -4
  167. package/dist/extensions/device-pair/index.d.ts +1 -1
  168. package/dist/extensions/device-pair/index.js +4 -4
  169. package/dist/extensions/diagnostics-otel/index.d.ts +1 -1
  170. package/dist/extensions/diagnostics-otel/index.js +4 -4
  171. package/dist/extensions/diffs/index.d.ts +1 -1
  172. package/dist/extensions/discord/index.d.ts +1 -1
  173. package/dist/extensions/discord/index.js +40 -40
  174. package/dist/extensions/discord/setup-entry.d.ts +1 -1
  175. package/dist/extensions/discord/setup-entry.js +38 -38
  176. package/dist/extensions/elevenlabs/index.d.ts +1 -1
  177. package/dist/extensions/elevenlabs/index.js +35 -35
  178. package/dist/extensions/feishu/index.d.ts +2 -2
  179. package/dist/extensions/feishu/index.js +40 -40
  180. package/dist/extensions/feishu/setup-entry.d.ts +2 -2
  181. package/dist/extensions/feishu/setup-entry.js +37 -37
  182. package/dist/extensions/firecrawl/index.d.ts +1 -1
  183. package/dist/extensions/firecrawl/index.js +35 -35
  184. package/dist/extensions/github-copilot/index.d.ts +1 -1
  185. package/dist/extensions/github-copilot/index.js +35 -35
  186. package/dist/extensions/google/index.d.ts +1 -1
  187. package/dist/extensions/google/index.js +35 -35
  188. package/dist/extensions/googlechat/index.d.ts +1 -1
  189. package/dist/extensions/googlechat/index.js +38 -38
  190. package/dist/extensions/googlechat/setup-entry.d.ts +1 -1
  191. package/dist/extensions/googlechat/setup-entry.js +38 -38
  192. package/dist/extensions/huggingface/index.d.ts +1 -1
  193. package/dist/extensions/huggingface/index.js +35 -35
  194. package/dist/extensions/imessage/index.d.ts +1 -1
  195. package/dist/extensions/imessage/index.js +39 -39
  196. package/dist/extensions/imessage/setup-entry.d.ts +1 -1
  197. package/dist/extensions/imessage/setup-entry.js +39 -39
  198. package/dist/extensions/irc/index.d.ts +1 -1
  199. package/dist/extensions/irc/index.js +38 -38
  200. package/dist/extensions/irc/setup-entry.d.ts +2 -2
  201. package/dist/extensions/irc/setup-entry.js +38 -38
  202. package/dist/extensions/kakao-talkchannel/index.d.ts +1 -1
  203. package/dist/extensions/kakao-talkchannel/index.js +4 -4
  204. package/dist/extensions/kilocode/index.d.ts +1 -1
  205. package/dist/extensions/kilocode/index.js +35 -35
  206. package/dist/extensions/kimi-coding/index.d.ts +1 -1
  207. package/dist/extensions/kimi-coding/index.js +35 -35
  208. package/dist/extensions/line/index.d.ts +1 -1
  209. package/dist/extensions/line/index.js +37 -37
  210. package/dist/extensions/line/setup-entry.d.ts +1 -1
  211. package/dist/extensions/line/setup-entry.js +37 -37
  212. package/dist/extensions/llm-task/index.d.ts +1 -1
  213. package/dist/extensions/llm-task/index.js +35 -35
  214. package/dist/extensions/lobster/index.d.ts +1 -1
  215. package/dist/extensions/lobster/index.js +4 -4
  216. package/dist/extensions/matrix/index.d.ts +1 -1
  217. package/dist/extensions/matrix/index.js +40 -40
  218. package/dist/extensions/matrix/setup-entry.d.ts +2 -2
  219. package/dist/extensions/matrix/setup-entry.js +40 -40
  220. package/dist/extensions/mattermost/index.d.ts +1 -1
  221. package/dist/extensions/mattermost/index.js +37 -37
  222. package/dist/extensions/mattermost/setup-entry.d.ts +2 -2
  223. package/dist/extensions/mattermost/setup-entry.js +37 -37
  224. package/dist/extensions/memory-core/index.d.ts +1 -1
  225. package/dist/extensions/memory-core/index.js +4 -4
  226. package/dist/extensions/memory-lancedb/index.d.ts +1 -1
  227. package/dist/extensions/memory-lancedb/index.js +4 -4
  228. package/dist/extensions/microsoft/index.d.ts +1 -1
  229. package/dist/extensions/microsoft/index.js +35 -35
  230. package/dist/extensions/minimax/index.d.ts +1 -1
  231. package/dist/extensions/minimax/index.js +35 -35
  232. package/dist/extensions/mistral/index.d.ts +1 -1
  233. package/dist/extensions/mistral/index.js +35 -35
  234. package/dist/extensions/modelstudio/index.d.ts +1 -1
  235. package/dist/extensions/modelstudio/index.js +35 -35
  236. package/dist/extensions/moonshot/index.d.ts +1 -1
  237. package/dist/extensions/moonshot/index.js +35 -35
  238. package/dist/extensions/msteams/index.d.ts +1 -1
  239. package/dist/extensions/msteams/index.js +40 -40
  240. package/dist/extensions/msteams/setup-entry.d.ts +1 -1
  241. package/dist/extensions/msteams/setup-entry.js +40 -40
  242. package/dist/extensions/nextcloud-talk/index.d.ts +1 -1
  243. package/dist/extensions/nextcloud-talk/index.js +37 -37
  244. package/dist/extensions/nextcloud-talk/setup-entry.d.ts +2 -2
  245. package/dist/extensions/nextcloud-talk/setup-entry.js +37 -37
  246. package/dist/extensions/nostr/index.d.ts +1 -1
  247. package/dist/extensions/nostr/index.js +37 -37
  248. package/dist/extensions/nostr/setup-entry.d.ts +1 -1
  249. package/dist/extensions/nostr/setup-entry.js +37 -37
  250. package/dist/extensions/nvidia/index.d.ts +1 -1
  251. package/dist/extensions/nvidia/index.js +4 -4
  252. package/dist/extensions/ollama/index.d.ts +1 -1
  253. package/dist/extensions/ollama/index.js +7 -7
  254. package/dist/extensions/open-prose/index.d.ts +1 -1
  255. package/dist/extensions/open-prose/index.js +4 -4
  256. package/dist/extensions/openai/index.d.ts +1 -1
  257. package/dist/extensions/openai/index.js +35 -35
  258. package/dist/extensions/opencode/index.d.ts +1 -1
  259. package/dist/extensions/opencode/index.js +35 -35
  260. package/dist/extensions/opencode-go/index.d.ts +1 -1
  261. package/dist/extensions/opencode-go/index.js +35 -35
  262. package/dist/extensions/openrouter/index.d.ts +1 -1
  263. package/dist/extensions/openrouter/index.js +35 -35
  264. package/dist/extensions/openshell/index.d.ts +1 -1
  265. package/dist/extensions/openshell/index.js +35 -35
  266. package/dist/extensions/perplexity/index.d.ts +1 -1
  267. package/dist/extensions/perplexity/index.js +5 -5
  268. package/dist/extensions/phone-control/index.d.ts +1 -1
  269. package/dist/extensions/phone-control/index.js +4 -4
  270. package/dist/extensions/qianfan/index.d.ts +1 -1
  271. package/dist/extensions/qianfan/index.js +35 -35
  272. package/dist/extensions/qwen-portal-auth/index.d.ts +1 -1
  273. package/dist/extensions/qwen-portal-auth/index.js +35 -35
  274. package/dist/extensions/sglang/index.d.ts +1 -1
  275. package/dist/extensions/sglang/index.js +35 -35
  276. package/dist/extensions/signal/index.d.ts +1 -1
  277. package/dist/extensions/signal/index.js +38 -38
  278. package/dist/extensions/signal/setup-entry.d.ts +1 -1
  279. package/dist/extensions/signal/setup-entry.js +38 -38
  280. package/dist/extensions/slack/index.d.ts +1 -1
  281. package/dist/extensions/slack/index.js +39 -39
  282. package/dist/extensions/slack/setup-entry.d.ts +1 -1
  283. package/dist/extensions/slack/setup-entry.js +38 -38
  284. package/dist/extensions/synology-chat/index.d.ts +1 -1
  285. package/dist/extensions/synology-chat/index.js +37 -37
  286. package/dist/extensions/synology-chat/setup-entry.d.ts +1 -1
  287. package/dist/extensions/synology-chat/setup-entry.js +37 -37
  288. package/dist/extensions/synthetic/index.d.ts +1 -1
  289. package/dist/extensions/synthetic/index.js +35 -35
  290. package/dist/extensions/talk-voice/index.d.ts +1 -1
  291. package/dist/extensions/talk-voice/index.js +35 -35
  292. package/dist/extensions/telegram/index.d.ts +1 -1
  293. package/dist/extensions/telegram/index.js +38 -38
  294. package/dist/extensions/telegram/setup-entry.d.ts +1 -1
  295. package/dist/extensions/telegram/setup-entry.js +37 -37
  296. package/dist/extensions/thread-ownership/index.d.ts +1 -1
  297. package/dist/extensions/thread-ownership/index.js +4 -4
  298. package/dist/extensions/tlon/index.d.ts +1 -1
  299. package/dist/extensions/tlon/index.js +37 -37
  300. package/dist/extensions/tlon/setup-entry.d.ts +1 -1
  301. package/dist/extensions/tlon/setup-entry.js +37 -37
  302. package/dist/extensions/together/index.d.ts +1 -1
  303. package/dist/extensions/together/index.js +35 -35
  304. package/dist/extensions/twitch/index.d.ts +2 -2
  305. package/dist/extensions/twitch/index.js +37 -37
  306. package/dist/extensions/venice/index.d.ts +1 -1
  307. package/dist/extensions/venice/index.js +35 -35
  308. package/dist/extensions/vercel-ai-gateway/index.d.ts +1 -1
  309. package/dist/extensions/vercel-ai-gateway/index.js +36 -36
  310. package/dist/extensions/vllm/index.d.ts +1 -1
  311. package/dist/extensions/vllm/index.js +35 -35
  312. package/dist/extensions/voice-call/index.d.ts +1 -1
  313. package/dist/extensions/voice-call/index.js +35 -35
  314. package/dist/extensions/volcengine/index.d.ts +1 -1
  315. package/dist/extensions/volcengine/index.js +35 -35
  316. package/dist/extensions/whatsapp/index.d.ts +1 -1
  317. package/dist/extensions/whatsapp/index.js +38 -38
  318. package/dist/extensions/whatsapp/setup-entry.d.ts +1 -1
  319. package/dist/extensions/whatsapp/setup-entry.js +38 -38
  320. package/dist/extensions/xai/index.d.ts +1 -1
  321. package/dist/extensions/xai/index.js +35 -35
  322. package/dist/extensions/xiaomi/index.d.ts +1 -1
  323. package/dist/extensions/xiaomi/index.js +35 -35
  324. package/dist/extensions/zai/index.d.ts +1 -1
  325. package/dist/extensions/zai/index.js +35 -35
  326. package/dist/extensions/zalo/index.d.ts +1 -1
  327. package/dist/extensions/zalo/index.js +39 -39
  328. package/dist/extensions/zalo/setup-entry.d.ts +1 -1
  329. package/dist/extensions/zalo/setup-entry.js +39 -39
  330. package/dist/extensions/zalouser/index.d.ts +1 -1
  331. package/dist/extensions/zalouser/index.js +40 -40
  332. package/dist/extensions/zalouser/setup-entry.d.ts +1 -1
  333. package/dist/extensions/zalouser/setup-entry.js +40 -40
  334. package/dist/feishu-fIcnHDTd.d.ts +36 -0
  335. package/dist/gateway-cli-0c-8h93_.js +26437 -0
  336. package/dist/gateway-install-token-1PwJvrBY.js +163 -0
  337. package/dist/gateway-rpc-C0Vk51W7.js +26 -0
  338. package/dist/gateway-runtime-CBm3CCoA.js +69 -0
  339. package/dist/git-commit-BTWXFY41.js +177 -0
  340. package/dist/git-commit-D6GTN5Yt.js +2 -0
  341. package/dist/googlechat-BQr4xgoZ.js +307 -0
  342. package/dist/googlechat-BvwsCVKl.d.ts +12 -0
  343. package/dist/group-access-DpiQnd-G.d.ts +61 -0
  344. package/dist/health-6yZQGADY.js +113 -0
  345. package/dist/health-C9DYGyRe.js +570 -0
  346. package/dist/heartbeat-summary-Dct2lqJj.js +57 -0
  347. package/dist/help-CtwSApfq.js +81 -0
  348. package/dist/hooks-9gokOxZ5.d.ts +6 -0
  349. package/dist/hooks-cli-BegKzHZT.js +1000 -0
  350. package/dist/hooks-status-Bm_pGORf.js +78 -0
  351. package/dist/http-registry-D-S6a1Na.d.ts +20 -0
  352. package/dist/identity-file-Diub2a0t.js +60 -0
  353. package/dist/image-generation-CbIVzmAR.d.ts +9 -0
  354. package/dist/imessage-Bgok9kfl.js +31 -0
  355. package/dist/imessage-VIHePprL.js +115 -0
  356. package/dist/inbound-reply-dispatch-B53GAGWq.js +71 -0
  357. package/dist/inbound-reply-dispatch-n7U3qg15.d.ts +72 -0
  358. package/dist/index.js +2 -2
  359. package/dist/install-target-oz1pjfHH.js +574 -0
  360. package/dist/installs-CUFm5V8a.js +532 -0
  361. package/dist/io-BaBxjB1v.js +9739 -0
  362. package/dist/io-CgHb1Jld.js +29 -0
  363. package/dist/irc-CaRKzGvW.js +672 -0
  364. package/dist/library-C5SNBCMb.js +112 -0
  365. package/dist/lifecycle-core-Dn8PK6nk.js +382 -0
  366. package/dist/line/accounts.d.ts +2 -2
  367. package/dist/line/send.d.ts +1 -1
  368. package/dist/line/send.js +7 -7
  369. package/dist/line/template-messages.d.ts +1 -1
  370. package/dist/line-B5QFpgN_.d.ts +75 -0
  371. package/dist/line-fePrrQOD.js +530 -0
  372. package/dist/llm-slug-generator-hKae3XDA.js +67 -0
  373. package/dist/llm-slug-generator.d.ts +1 -1
  374. package/dist/llm-slug-generator.js +36 -36
  375. package/dist/logging-CdisccbY.js +13 -0
  376. package/dist/logging-LKQSgX1d.js +30 -0
  377. package/dist/login-qr-C1YWh4nE.js +233 -0
  378. package/dist/login-qr-WFluMDMb.js +112 -0
  379. package/dist/logs-cli-CNzOvZ2d.js +256 -0
  380. package/dist/manager-runtime-DgMhLTkR.js +111 -0
  381. package/dist/manager.runtime-hUWgpPt2.js +715 -0
  382. package/dist/manifest-registry-CS_p1OBQ.js +1329 -0
  383. package/dist/matrix-43_RGLZN.d.ts +68 -0
  384. package/dist/matrix-CCFxHfxa.js +1269 -0
  385. package/dist/matrix-DWs_qIkJ.js +1495 -0
  386. package/dist/mcp-cli-Ci2jvv3s.js +87 -0
  387. package/dist/media-understanding.runtime-Cdr6iTW6.js +116 -0
  388. package/dist/memory-cli-LZbyF0Iu.js +111 -0
  389. package/dist/memory-search-BHhETk6u.js +17 -0
  390. package/dist/memory-search-tTD5o_rU.js +204 -0
  391. package/dist/method-scopes-B2ZKSsxQ.js +2452 -0
  392. package/dist/model-auth-markers-LqZ4qhrZ.d.ts +20 -0
  393. package/dist/model-picker-CTR5mo4v.js +112 -0
  394. package/dist/model-picker-DG4z_dBs.js +390 -0
  395. package/dist/model-picker.runtime-DMQ9Pj9_.js +125 -0
  396. package/dist/model-selection-bBBxfXdb.js +653 -0
  397. package/dist/model-suppression.runtime-BVG75tZ7.js +116 -0
  398. package/dist/models-BjkVLfgw.js +2514 -0
  399. package/dist/models-ZO01Q4cx.js +118 -0
  400. package/dist/models-cli-DemdF-bm.js +309 -0
  401. package/dist/models-config-B2Jja8ua.js +111 -0
  402. package/dist/models-config.providers.discovery-puxTsH39.d.ts +18 -0
  403. package/dist/moldclaw-root-Cb6HRlUO.js +92 -0
  404. package/dist/monitor-BP4idxJD.js +782 -0
  405. package/dist/monitor-B_eP8Eim.js +772 -0
  406. package/dist/monitor-CRHYNl5J.js +3468 -0
  407. package/dist/monitor-Ci1Xg4g3.js +113 -0
  408. package/dist/monitor-DEodDl3z.js +6823 -0
  409. package/dist/monitor-DJlNKuMz.js +115 -0
  410. package/dist/monitor-DvFwDS9w.js +3076 -0
  411. package/dist/monitor-shared--cEjSf8s.js +444 -0
  412. package/dist/msteams-CV2a8uE8.js +852 -0
  413. package/dist/node-cli-Of2g7DSd.js +2503 -0
  414. package/dist/node-resolve-BYC2FbO2.js +835 -0
  415. package/dist/nodes-cli-CPHM6Upj.js +1380 -0
  416. package/dist/nostr-BFKRoOlz.d.ts +7 -0
  417. package/dist/nostr-lHpcBzz4.js +8744 -0
  418. package/dist/npm-resolution-kqHN85wB.js +60 -0
  419. package/dist/oauth-env-CLG8KOrz.js +10 -0
  420. package/dist/onboard-BON0C360.js +48 -0
  421. package/dist/onboard-CRkIBgOI.js +589 -0
  422. package/dist/onboard-DsKI17iq.js +25 -0
  423. package/dist/onboard-channels-BY3IbBBf.js +1241 -0
  424. package/dist/onboard-channels-CLKdRxvW.js +205 -0
  425. package/dist/onboard-custom-BjPrMo_R.js +571 -0
  426. package/dist/onboard-custom-DqcPiZBN.js +114 -0
  427. package/dist/onboard-helpers-BkrOY5OE.js +113 -0
  428. package/dist/onboard-helpers-DiSRTpZC.js +335 -0
  429. package/dist/onboard-hooks-pzEPZAvl.js +72 -0
  430. package/dist/onboard-remote-ChyLC6Dk.js +181 -0
  431. package/dist/onboard-remote-DHmK9ntl.js +117 -0
  432. package/dist/onboard-search-BgA3jEMW.js +302 -0
  433. package/dist/onboard-skills-BMo_NvnW.js +133 -0
  434. package/dist/onboard-skills-Bba-Z2p8.js +117 -0
  435. package/dist/outbound-media-BHD4aJEX.d.ts +11 -0
  436. package/dist/outbound-media-DSno0N82.js +11 -0
  437. package/dist/pairing-access-CzHpaM0R.d.ts +21 -0
  438. package/dist/pairing-cli-CmklqK0q.js +217 -0
  439. package/dist/perplexity-CXwMDD3u.js +24 -0
  440. package/dist/persistent-dedupe-B9vrAf8t.d.ts +26 -0
  441. package/dist/pi-model-discovery-runtime-BrK7tcaO.js +111 -0
  442. package/dist/pi-tools.before-tool-call.runtime-C5yLUogH.js +381 -0
  443. package/dist/plugin-install-C4AWJIFP.js +117 -0
  444. package/dist/plugin-install-CB3J1hfV.js +184 -0
  445. package/dist/plugin-install-plan-7itZiegi.js +49 -0
  446. package/dist/plugin-registry-DX_GFoiz.js +113 -0
  447. package/dist/plugin-registry-e3cxTtvb.js +49 -0
  448. package/dist/plugin-sdk/account-resolution.js +35 -35
  449. package/dist/plugin-sdk/acp-runtime.js +35 -35
  450. package/dist/plugin-sdk/agent-runtime.js +35 -35
  451. package/dist/plugin-sdk/bluebubbles.js +37 -37
  452. package/dist/plugin-sdk/channel-config-helpers.js +35 -35
  453. package/dist/plugin-sdk/channel-policy.js +35 -35
  454. package/dist/plugin-sdk/channel-runtime.js +35 -35
  455. package/dist/plugin-sdk/compat.js +36 -36
  456. package/dist/plugin-sdk/config-runtime.js +35 -35
  457. package/dist/plugin-sdk/conversation-runtime.js +35 -35
  458. package/dist/plugin-sdk/copilot-proxy.js +4 -4
  459. package/dist/plugin-sdk/core.js +4 -4
  460. package/dist/plugin-sdk/device-pair.js +4 -4
  461. package/dist/plugin-sdk/discord.js +35 -35
  462. package/dist/plugin-sdk/feishu.js +35 -35
  463. package/dist/plugin-sdk/gateway-runtime.js +10 -10
  464. package/dist/plugin-sdk/googlechat.js +37 -37
  465. package/dist/plugin-sdk/image-generation-runtime.js +35 -35
  466. package/dist/plugin-sdk/image-generation.js +35 -35
  467. package/dist/plugin-sdk/imessage.js +36 -36
  468. package/dist/plugin-sdk/index.js +35 -35
  469. package/dist/plugin-sdk/infra-runtime.js +35 -35
  470. package/dist/plugin-sdk/irc.js +37 -37
  471. package/dist/plugin-sdk/line.js +36 -36
  472. package/dist/plugin-sdk/llm-task.js +35 -35
  473. package/dist/plugin-sdk/lobster.js +4 -4
  474. package/dist/plugin-sdk/matrix.js +37 -37
  475. package/dist/plugin-sdk/mattermost.js +36 -36
  476. package/dist/plugin-sdk/media-runtime.js +35 -35
  477. package/dist/plugin-sdk/media-understanding-runtime.js +35 -35
  478. package/dist/plugin-sdk/media-understanding.js +35 -35
  479. package/dist/plugin-sdk/memory-lancedb.js +4 -4
  480. package/dist/plugin-sdk/minimax-portal-auth.js +4 -4
  481. package/dist/plugin-sdk/msteams.js +38 -38
  482. package/dist/plugin-sdk/nextcloud-talk.js +36 -36
  483. package/dist/plugin-sdk/nostr.js +36 -36
  484. package/dist/plugin-sdk/ollama-setup.js +9 -9
  485. package/dist/plugin-sdk/open-prose.js +4 -4
  486. package/dist/plugin-sdk/phone-control.js +4 -4
  487. package/dist/plugin-sdk/plugin-runtime.js +35 -35
  488. package/dist/plugin-sdk/provider-auth.js +35 -35
  489. package/dist/plugin-sdk/provider-models.js +5 -5
  490. package/dist/plugin-sdk/provider-onboard.js +4 -4
  491. package/dist/plugin-sdk/provider-setup.js +39 -39
  492. package/dist/plugin-sdk/provider-stream.js +4 -4
  493. package/dist/plugin-sdk/provider-usage.js +4 -4
  494. package/dist/plugin-sdk/qwen-portal-auth.js +35 -35
  495. package/dist/plugin-sdk/reply-history.js +35 -35
  496. package/dist/plugin-sdk/reply-runtime.js +35 -35
  497. package/dist/plugin-sdk/routing.js +3 -3
  498. package/dist/plugin-sdk/sandbox.js +35 -35
  499. package/dist/plugin-sdk/security-runtime.js +35 -35
  500. package/dist/plugin-sdk/self-hosted-provider-setup.js +37 -37
  501. package/dist/plugin-sdk/setup.js +35 -35
  502. package/dist/plugin-sdk/signal.js +35 -35
  503. package/dist/plugin-sdk/slack.js +35 -35
  504. package/dist/plugin-sdk/speech-runtime.js +35 -35
  505. package/dist/plugin-sdk/speech.js +35 -35
  506. package/dist/plugin-sdk/src/secrets/secure-file-store.d.ts +26 -0
  507. package/dist/plugin-sdk/src/subscription/provider.d.ts +5 -3
  508. package/dist/plugin-sdk/synology-chat.js +36 -36
  509. package/dist/plugin-sdk/talk-voice.js +4 -4
  510. package/dist/plugin-sdk/telegram.js +35 -35
  511. package/dist/plugin-sdk/text-runtime.js +7 -7
  512. package/dist/plugin-sdk/thread-ownership.js +4 -4
  513. package/dist/plugin-sdk/tlon.js +36 -36
  514. package/dist/plugin-sdk/twitch.js +35 -35
  515. package/dist/plugin-sdk/voice-call.js +35 -35
  516. package/dist/plugin-sdk/whatsapp.js +35 -35
  517. package/dist/plugin-sdk/zalo.js +38 -38
  518. package/dist/plugin-sdk/zalouser.js +38 -38
  519. package/dist/plugins/runtime/index.d.ts +1 -1
  520. package/dist/plugins/runtime/index.js +35 -35
  521. package/dist/plugins-DF5FaTO0.js +111 -0
  522. package/dist/plugins-cli-CvTJemqC.js +917 -0
  523. package/dist/policy-CNXISK_a.js +143 -0
  524. package/dist/preflight-audio.runtime-RP000oxo.js +116 -0
  525. package/dist/probe-BkM5pykD.js +21 -0
  526. package/dist/probe-DKbRTJv5.js +1793 -0
  527. package/dist/probe-DkrfRsjU.js +47 -0
  528. package/dist/probe-DpcJ0WeP.js +129 -0
  529. package/dist/probe-auth-BcNjX8hy.js +40 -0
  530. package/dist/probe-auth-DhuAb8ls.js +48 -0
  531. package/dist/probe-wciBj-aL.js +6329 -0
  532. package/dist/program-C8-p0mW5.js +253 -0
  533. package/dist/prompt-select-styled-DH0pVoc0.js +2673 -0
  534. package/dist/provider-api-key-auth.runtime-CAFeIQ1u.js +121 -0
  535. package/dist/provider-auth-choice-CB_HzdTl.js +126 -0
  536. package/dist/provider-auth-choice-helpers-hzDkh3f1.js +48 -0
  537. package/dist/provider-auth-choice-preference-BHCXvNSE.js +189 -0
  538. package/dist/provider-auth-choice.runtime-Dx4ms2C5.js +123 -0
  539. package/dist/provider-auth-choices-0KaDNPBQ.js +57 -0
  540. package/dist/provider-auth-guidance-BaAUiNr_.js +34 -0
  541. package/dist/provider-auth-result-Bto1bYtS.d.ts +18 -0
  542. package/dist/provider-models-DxOmeToO.d.ts +867 -0
  543. package/dist/provider-models-xnyxy6mO.js +2113 -0
  544. package/dist/provider-ollama-setup-DBYK__ov.d.ts +32 -0
  545. package/dist/provider-ollama-setup-QzgCxj44.js +314 -0
  546. package/dist/provider-onboard-B9ionepI.js +139 -0
  547. package/dist/provider-onboard-CURxJ_UX.d.ts +40 -0
  548. package/dist/provider-runtime.runtime-4xwmsl5L.js +111 -0
  549. package/dist/provider-self-hosted-setup-BHd24EDG.js +182 -0
  550. package/dist/provider-self-hosted-setup-qeY8BYSy.d.ts +61 -0
  551. package/dist/provider-stream-Chz_EFw3.js +512 -0
  552. package/dist/provider-usage-C11Q7UwS.js +111 -0
  553. package/dist/provider-usage-kxemdMp2.js +633 -0
  554. package/dist/provider-wizard-CanJoxNC.js +152 -0
  555. package/dist/push-apns-Dsajnm8C.js +1038 -0
  556. package/dist/pw-ai-DUe4BbH2.js +1867 -0
  557. package/dist/qmd-manager-CAAFp7qK.js +1570 -0
  558. package/dist/qr-cli-Bu2jqTPY.js +113 -0
  559. package/dist/qr-cli-Bu9Z-X48.js +369 -0
  560. package/dist/reactions-Cpfum4iU.js +281 -0
  561. package/dist/read-only-account-inspect.discord.runtime-BK0LaMgC.js +116 -0
  562. package/dist/read-only-account-inspect.slack.runtime-DgKiC5wT.js +116 -0
  563. package/dist/read-only-account-inspect.telegram.runtime-mxfgFVOU.js +116 -0
  564. package/dist/redact-snapshot-DD8A4tdd.js +2663 -0
  565. package/dist/register.agent-DU4FtrU2.js +439 -0
  566. package/dist/register.backup-8nOYtJqg.js +625 -0
  567. package/dist/register.configure-DmtecqIH.js +252 -0
  568. package/dist/register.maintenance-Dir3ulKP.js +574 -0
  569. package/dist/register.message-Cfl-f3Ju.js +709 -0
  570. package/dist/register.onboard-Bv7WVzEi.js +192 -0
  571. package/dist/register.setup-BIyeI8RY.js +212 -0
  572. package/dist/register.status-health-sessions-C69WQcF4.js +498 -0
  573. package/dist/register.subclis-B_4KCgTd.js +315 -0
  574. package/dist/register.subclis-BeXsmgBL.js +13 -0
  575. package/dist/replies-DdcFUmki.js +110 -0
  576. package/dist/resolve-channels-DRZqPV5o.js +226 -0
  577. package/dist/resolve-channels-DxW1kqxA.js +262 -0
  578. package/dist/resolve-route-DdX-HBVt.js +538 -0
  579. package/dist/resolve-users-rgCQvkLs.js +143 -0
  580. package/dist/root-help-QAkoA7GD.js +32 -0
  581. package/dist/routes-CcJNnwTF.js +7097 -0
  582. package/dist/rpc-DDUAlBbH.js +67 -0
  583. package/dist/run-main-D9ci5pn7.js +424 -0
  584. package/dist/runtime-Bitmi8Er.d.ts +26 -0
  585. package/dist/runtime-discord-ops.runtime-T4sf7aRB.js +9078 -0
  586. package/dist/runtime-slack-ops.runtime-BQpP48mC.js +4556 -0
  587. package/dist/runtime-telegram-ops.runtime-cVO5dqOp.js +133 -0
  588. package/dist/runtime-whatsapp-login.runtime-DtNx0dSY.js +114 -0
  589. package/dist/runtime-whatsapp-outbound.runtime-Bw47QbFK.js +117 -0
  590. package/dist/sandbox-cli-DsFwjbjC.js +535 -0
  591. package/dist/search-manager-BRAK8fEe.js +16 -0
  592. package/dist/search-manager-BS5Db0A6.js +386 -0
  593. package/dist/secrets-cli-D3J46TJp.js +2070 -0
  594. package/dist/security-cli-B866M9cB.js +575 -0
  595. package/dist/send-B1pX9_Oc.js +283 -0
  596. package/dist/send-B2RrLg83.js +100 -0
  597. package/dist/send-DFnV__Aq.js +1025 -0
  598. package/dist/send-DZIH6CJt.js +629 -0
  599. package/dist/send-sl9WnKbW.js +631 -0
  600. package/dist/server-node-events-BT6egg20.js +506 -0
  601. package/dist/server-zI_K-D05.js +107 -0
  602. package/dist/sessions-C8kiAcoJ.js +112 -0
  603. package/dist/sessions-DLBpp52_.js +218 -0
  604. package/dist/setup-C7eOzMiC.js +387 -0
  605. package/dist/setup-CFIMq-Pz.d.ts +37 -0
  606. package/dist/setup-binary-CcAv8NXz.js +406 -0
  607. package/dist/setup-browser-C4eRV3h6.js +70 -0
  608. package/dist/setup-core-BnR486P-.js +143 -0
  609. package/dist/setup-core-CIswIiu5.js +166 -0
  610. package/dist/setup-core-CcbcrXXg.js +47 -0
  611. package/dist/setup-core-nZSw5BSv.js +205 -0
  612. package/dist/setup-surface-C5iSpT4M.js +490 -0
  613. package/dist/setup-wizard-helpers-r0J6l8ST.d.ts +203 -0
  614. package/dist/setup.finalize-adiRfo0U.js +522 -0
  615. package/dist/setup.gateway-config-BwFWKDfT.js +343 -0
  616. package/dist/shared-12TimyeF.js +182 -0
  617. package/dist/shared-9EWO34-k.js +298 -0
  618. package/dist/shared-B4vUbaRR.js +75 -0
  619. package/dist/shared-bNWpW3Dd.js +96 -0
  620. package/dist/shared-lU1y5dvS.js +102 -0
  621. package/dist/signal-DBlETRu9.js +114 -0
  622. package/dist/skills-Bio8GwTE.js +20 -0
  623. package/dist/skills-DE_MXFSN.js +853 -0
  624. package/dist/skills-cli-BGuW-tKw.js +292 -0
  625. package/dist/skills-install--rnorIoJ.js +763 -0
  626. package/dist/skills-status-B08PtBc_.js +21 -0
  627. package/dist/skills-status-CzM008aB.js +169 -0
  628. package/dist/slack-C4T53Nc-.js +114 -0
  629. package/dist/slash-commands.runtime-B7fsD8Be.js +128 -0
  630. package/dist/slash-dispatch.runtime-t0PAX4vQ.js +141 -0
  631. package/dist/slash-skill-commands.runtime-DIhPnEfR.js +116 -0
  632. package/dist/src-DrDirlvw.js +1701 -0
  633. package/dist/status-Bld14WSA.js +131 -0
  634. package/dist/status-CgeO4RuH.js +43 -0
  635. package/dist/status-HlvixAOq.js +606 -0
  636. package/dist/status-Rom_Lf3c.js +1599 -0
  637. package/dist/status-TwbMH6Am.js +126 -0
  638. package/dist/status-json-DMW7cmuK.js +288 -0
  639. package/dist/status.link-channel-V4LkB6Gq.js +143 -0
  640. package/dist/status.scan.deps.runtime-BE3X-dcP.js +126 -0
  641. package/dist/status.scan.runtime-BxVY4mty.js +119 -0
  642. package/dist/status.summary-CzLM0vVr.js +592 -0
  643. package/dist/status.summary.runtime-BSBnHZ1Q.js +118 -0
  644. package/dist/status.update-BxblMS7P.js +77 -0
  645. package/dist/subagent-orphan-recovery-BpRPryEj.js +307 -0
  646. package/dist/subagent-registry-runtime-DYYU5p3X.js +111 -0
  647. package/dist/subscription-CpFdxuFS.js +33 -0
  648. package/dist/subscription-DaA1urx-.js +102 -0
  649. package/dist/subscription-cli-Bvto9EmO.js +134 -0
  650. package/dist/synology-chat-3nwk-Nj0.js +297 -0
  651. package/dist/system-cli-BvNps8sl.js +94 -0
  652. package/dist/telegram/audit.d.ts +1 -1
  653. package/dist/telegram/audit.js +1 -1
  654. package/dist/telegram/token.d.ts +1 -1
  655. package/dist/telegram/token.js +35 -35
  656. package/dist/telegram-RtKXoEsF.js +114 -0
  657. package/dist/text-chunking-BD5mQe2R.js +84 -0
  658. package/dist/text-chunking-DDUU_vAF.d.ts +79 -0
  659. package/dist/tlon-z-kYmJE-.js +433 -0
  660. package/dist/tui-cli-CzSK08Rh.js +137 -0
  661. package/dist/tui-wV7R1Tlc.js +3834 -0
  662. package/dist/types-2H_e7eWT.d.ts +45 -0
  663. package/dist/types-ZKnGUchG.d.ts +22692 -0
  664. package/dist/types.base-BFiQZ4J9.d.ts +188 -0
  665. package/dist/ui-BWVHreeR.js +31 -0
  666. package/dist/update-D1Wgh1Tj.js +1036 -0
  667. package/dist/update-cli-CZh99uyY.js +1503 -0
  668. package/dist/update-offset-store-D5xTdUr0.js +112 -0
  669. package/dist/update-runner-GbKfoCHs.js +1496 -0
  670. package/dist/upsert-with-lock-BZU7Le8n.js +33 -0
  671. package/dist/usage-Czgwvg0h.js +115 -0
  672. package/dist/web-CMczmL90.js +112 -0
  673. package/dist/web-shared-B5Q0mIJq.d.ts +45 -0
  674. package/dist/webhook-request-guards-CsKDhZJr.d.ts +76 -0
  675. package/dist/webhook-targets-BSmFtesN.js +181 -0
  676. package/dist/webhook-targets-CjxuEE9C.d.ts +106 -0
  677. package/dist/webhooks-cli-Wl9y6AWW.js +350 -0
  678. package/dist/whatsapp-VzRW8MdR.js +114 -0
  679. package/dist/whatsapp-actions-Cg1Wxv8W.js +167 -0
  680. package/dist/workspace-DJ_S272u.js +484 -0
  681. package/dist/workspace-DbZSqjw0.js +289 -0
  682. package/dist/workspace-cli-D93DLmAh.js +154 -0
  683. package/dist/workspace-dirs-CGeIPpGN.js +2003 -0
  684. package/dist/zalo-CK2dlGmu.d.ts +9 -0
  685. package/dist/zalo-Db7s2boL.js +415 -0
  686. package/dist/zalouser-Jh5YTJX3.js +30911 -0
  687. package/docs/reference/templates/AGENTS.dev.md +83 -0
  688. package/docs/reference/templates/AGENTS.md +219 -0
  689. package/docs/reference/templates/BOOT.md +11 -0
  690. package/docs/reference/templates/BOOTSTRAP.md +62 -0
  691. package/docs/reference/templates/HEARTBEAT.md +12 -0
  692. package/docs/reference/templates/IDENTITY.dev.md +47 -0
  693. package/docs/reference/templates/IDENTITY.md +29 -0
  694. package/docs/reference/templates/SOUL.dev.md +76 -0
  695. package/docs/reference/templates/SOUL.md +43 -0
  696. package/docs/reference/templates/TOOLS.dev.md +24 -0
  697. package/docs/reference/templates/TOOLS.md +47 -0
  698. package/docs/reference/templates/USER.dev.md +18 -0
  699. package/docs/reference/templates/USER.md +23 -0
  700. package/extensions/discord/src/monitor/allow-list.ts +8 -1
  701. package/extensions/discord/src/monitor/message-handler.preflight.ts +4 -1
  702. package/package.json +2 -1
  703. package/dist/accounts-CDr-lDaV.d.ts +0 -103
  704. package/dist/accounts-CS8U4v8C.js +0 -114
  705. package/dist/acp-cli-BGT0jXcC.js +0 -2093
  706. package/dist/actions.runtime-BfckTw6c.js +0 -119
  707. package/dist/actions.runtime-Cl9mBfqH.js +0 -133
  708. package/dist/agent-scope-C-YmLnnb.js +0 -208
  709. package/dist/agents-CydD54p8.js +0 -222
  710. package/dist/agents-DpQsZO6O.js +0 -853
  711. package/dist/agents.config-XU7IsYE-.js +0 -121
  712. package/dist/agents.config-ssoQXuvF.js +0 -17
  713. package/dist/allow-list-Cfn6lmMK.js +0 -81
  714. package/dist/allowlist-CCYXVpM9.js +0 -142
  715. package/dist/api-BoXoFKxy.js +0 -117
  716. package/dist/audit-Bv05N5o9.js +0 -787
  717. package/dist/audit-CIWW1Aqm.js +0 -54
  718. package/dist/audit-channel.collect.runtime-Bi7yrdcO.js +0 -605
  719. package/dist/audit-channel.runtime-C_NDweiW.js +0 -121
  720. package/dist/audit-extra.async-Dp7OKSXg.js +0 -813
  721. package/dist/audit-membership-runtime-B8FQ6VtN.js +0 -162
  722. package/dist/audit.deep.runtime-CXhobL6b.js +0 -25
  723. package/dist/audit.nondeep.runtime-CrEm3T16.js +0 -832
  724. package/dist/audit.runtime-CJPKj1Zg.js +0 -118
  725. package/dist/auth-Byfp0flq.js +0 -101
  726. package/dist/auth-choice-BgOjdeXN.js +0 -507
  727. package/dist/auth-choice-CD1Heq0M.js +0 -122
  728. package/dist/auth-choice-ePNfg0iQ.js +0 -268
  729. package/dist/auth-choice-options-BlewQWI0.js +0 -123
  730. package/dist/auth-choice-prompt-BP2b6aXz.js +0 -36
  731. package/dist/auth-choice-prompt-Cmwl4n97.js +0 -115
  732. package/dist/auth-choice.apply-helpers-Dq-nxuuX.js +0 -66
  733. package/dist/auth-choice.plugin-providers.runtime-B23kOUzQ.js +0 -119
  734. package/dist/auth-profiles-1kPLbBwI.js +0 -127823
  735. package/dist/auth-profiles.runtime-DAfSjku1.js +0 -116
  736. package/dist/banner-DeOsobLO.js +0 -342
  737. package/dist/bluebubbles-BsLGedBM.js +0 -64
  738. package/dist/bluebubbles-CnT9wiS4.d.ts +0 -6
  739. package/dist/bot-CuzVYwa_.d.ts +0 -478
  740. package/dist/brave-BoWimrLe.js +0 -24
  741. package/dist/browser-cli-D_S3wEYE.js +0 -1494
  742. package/dist/call-ByEzDJ1_.js +0 -640
  743. package/dist/call-CHCWVg-O.js +0 -39
  744. package/dist/channel-3VC0oOMu.js +0 -214
  745. package/dist/channel-B9fCBPiS.js +0 -207
  746. package/dist/channel-B9q775cM.js +0 -562
  747. package/dist/channel-BG3UK54j.js +0 -803
  748. package/dist/channel-BRQAdMML.js +0 -352
  749. package/dist/channel-BmlLp933.js +0 -1321
  750. package/dist/channel-By6KvdTG.js +0 -920
  751. package/dist/channel-C8rRsdf6.js +0 -226
  752. package/dist/channel-CLEDBbXE.js +0 -943
  753. package/dist/channel-CMvBAG7o.js +0 -306
  754. package/dist/channel-CmlxxjHY.js +0 -1598
  755. package/dist/channel-CqG6_xN0.js +0 -949
  756. package/dist/channel-DNueHKs92.js +0 -316
  757. package/dist/channel-DUtyN7BX.js +0 -4681
  758. package/dist/channel-DWD6GrfZ.js +0 -538
  759. package/dist/channel-DaRYMYzj.js +0 -619
  760. package/dist/channel-Dj6BgLp8.js +0 -575
  761. package/dist/channel-account-context-Ba3u5D21.js +0 -103
  762. package/dist/channel-crabk6Em.js +0 -542
  763. package/dist/channel-i8uqQaK2.js +0 -497
  764. package/dist/channel-options-xljvwHS2.js +0 -50
  765. package/dist/channel-plugin-ids-DAgknSG4.js +0 -26
  766. package/dist/channel-summary-dHTMCG75.js +0 -111
  767. package/dist/channel-xVWQ96Ni.js +0 -397
  768. package/dist/channel.runtime-B6PoZ4BV.js +0 -182
  769. package/dist/channel.runtime-BPZmo57e.js +0 -404
  770. package/dist/channel.runtime-B_1uGR-U.js +0 -199
  771. package/dist/channel.runtime-BiXnPU0d.js +0 -218
  772. package/dist/channel.runtime-BpvDc9sv.js +0 -870
  773. package/dist/channel.runtime-CUua3W80.js +0 -418
  774. package/dist/channel.runtime-CaCBTd0A.js +0 -179
  775. package/dist/channel.runtime-D0FfYvUj.js +0 -4011
  776. package/dist/channel.runtime-DhoJtpvJ.js +0 -241
  777. package/dist/channel.runtime-Kj9EXNE0.js +0 -127
  778. package/dist/channel.runtime-r4tPuPyh.js +0 -171
  779. package/dist/channel.setup-B7d_grfe.js +0 -6
  780. package/dist/channel.setup-C0vu1fhi.js +0 -9
  781. package/dist/channel.setup-CAI0FNHj.js +0 -11
  782. package/dist/channel.setup-CkDVwv5R.js +0 -57
  783. package/dist/channel.setup-Cpd00YqQ.js +0 -8
  784. package/dist/channel.setup-DbBz1-WT.js +0 -9
  785. package/dist/channel.setup-GZnAvD9g.js +0 -8
  786. package/dist/channels-5H484RSw.js +0 -1118
  787. package/dist/channels-BnPudfyx.js +0 -404
  788. package/dist/channels-cli-WIC-QeH_.js +0 -291
  789. package/dist/channels-status-issues-RDmzovJU.js +0 -16
  790. package/dist/clawbot-cli-BgutNwf8.js +0 -118
  791. package/dist/cleanup-utils-DBl1Aij1.js +0 -96
  792. package/dist/cli-1P7u6zqu.js +0 -154
  793. package/dist/command-registry-B8jovrws.js +0 -232
  794. package/dist/command-registry-DtDl1FVm.js +0 -14
  795. package/dist/command-secret-gateway-BgUo3FxJ.js +0 -111
  796. package/dist/compact.runtime-CXbXM0AU.js +0 -116
  797. package/dist/completion-cli-Cik_owAE.js +0 -17
  798. package/dist/completion-cli-RU3P2RSl.js +0 -445
  799. package/dist/config-5HUpB1L1.js +0 -31
  800. package/dist/config-cli-QHaUHoZI.js +0 -433
  801. package/dist/config-guard-C9Sn3pE-.js +0 -118
  802. package/dist/config-sW57gztj.js +0 -44
  803. package/dist/config-validation-5LkjIKNt.js +0 -262
  804. package/dist/config-value-CtTWALxG.js +0 -132
  805. package/dist/configure-BmR2TPLf.js +0 -243
  806. package/dist/configure-DaLN-5xM.js +0 -1100
  807. package/dist/control-ui-assets-CH3MYmAo.js +0 -232
  808. package/dist/control-ui-shared-CA77PTml.js +0 -29
  809. package/dist/core-CvDzLs7B.js +0 -150
  810. package/dist/core-jm751KJ9.d.ts +0 -87
  811. package/dist/cron-cli-tguLpzyq.js +0 -639
  812. package/dist/daemon-cli-ptosOkL8.js +0 -339
  813. package/dist/daemon-install-DzU4EnVa.js +0 -180
  814. package/dist/deliver-DwxFoHM3.js +0 -111
  815. package/dist/deliver-runtime-DOdDyaPI.js +0 -111
  816. package/dist/device-id-cli-GopvlxxZ.js +0 -52
  817. package/dist/device-identity-CRfhC3_s.js +0 -365
  818. package/dist/devices-cli-ain7ESqU.js +0 -342
  819. package/dist/diagnostic-D96Xaqrj.js +0 -310
  820. package/dist/directory-cli-fh1UxGgY.js +0 -311
  821. package/dist/directory-config-helpers-Coivm0Mt.d.ts +0 -38
  822. package/dist/directory.static-CKjJUNGl.js +0 -44
  823. package/dist/discord-CflhwDEM.js +0 -114
  824. package/dist/discovery-x0ZqY4AB.js +0 -48
  825. package/dist/dm-policy-shared-DKzsSLlO.d.ts +0 -95
  826. package/dist/dns-cli-DCHyKjGf.js +0 -217
  827. package/dist/docs-cli-D3OoqYSP.js +0 -174
  828. package/dist/doctor-completion-Bq2eP87s.js +0 -90
  829. package/dist/doctor-config-flow-D8XRG9Ku.js +0 -2437
  830. package/dist/doctor-config-flow-DGiF1HGc.js +0 -112
  831. package/dist/enable-0QSF4YGH.js +0 -24
  832. package/dist/exec-approvals-cli-Bncym0Gd.js +0 -421
  833. package/dist/feishu-C1dM8pl2.d.ts +0 -36
  834. package/dist/gateway-cli-DYscsmA-.js +0 -26437
  835. package/dist/gateway-install-token-CNv17ac9.js +0 -163
  836. package/dist/gateway-rpc-BGC1Rxvg.js +0 -26
  837. package/dist/gateway-runtime-D89mSQPB.js +0 -69
  838. package/dist/git-commit-CeLH5Ozm.js +0 -2
  839. package/dist/git-commit-DUKRiCP-.js +0 -177
  840. package/dist/googlechat-BgXeXjd1.js +0 -307
  841. package/dist/googlechat-CNZQb1jd.d.ts +0 -12
  842. package/dist/group-access-Deh1tVNr.d.ts +0 -61
  843. package/dist/health-BEjzWwaB.js +0 -570
  844. package/dist/health-FjqrWQL6.js +0 -113
  845. package/dist/heartbeat-summary-CfdSA9M1.js +0 -57
  846. package/dist/help-BZeVprq1.js +0 -81
  847. package/dist/hooks-06OUQvAV.d.ts +0 -6
  848. package/dist/hooks-cli-B7uGJs2O.js +0 -1000
  849. package/dist/hooks-status-CfceaUSg.js +0 -78
  850. package/dist/http-registry-DYskWhOr.d.ts +0 -20
  851. package/dist/identity-file-sshkKKIr.js +0 -60
  852. package/dist/image-generation-D4o3j8o6.d.ts +0 -9
  853. package/dist/imessage-BcV3WGx_.js +0 -31
  854. package/dist/imessage-Dhje7Ty-.js +0 -115
  855. package/dist/inbound-reply-dispatch-C73_7SOl.js +0 -71
  856. package/dist/inbound-reply-dispatch-D6_HNqH8.d.ts +0 -72
  857. package/dist/install-target-D7NRhfzc.js +0 -574
  858. package/dist/installs-Bj6jblqc.js +0 -532
  859. package/dist/io-CMfWWPXQ.js +0 -9738
  860. package/dist/io-CV844hAM.js +0 -29
  861. package/dist/irc-DKi1fDYI.js +0 -672
  862. package/dist/library-rygTG3oA.js +0 -112
  863. package/dist/lifecycle-core-BPlvShWY.js +0 -382
  864. package/dist/line-B8gTtl3Y.d.ts +0 -75
  865. package/dist/line-CGsemKWJ.js +0 -530
  866. package/dist/llm-slug-generator-DlhVyMqT.js +0 -67
  867. package/dist/logging-5wu9k6w4.js +0 -30
  868. package/dist/logging-CxP9suT8.js +0 -13
  869. package/dist/login-qr-BcDsiwHs.js +0 -233
  870. package/dist/login-qr-Y8pJ5yV4.js +0 -112
  871. package/dist/logs-cli-XI9oVXpH.js +0 -256
  872. package/dist/manager-runtime-DkIlXBhD.js +0 -111
  873. package/dist/manager.runtime-Q0q2rJCC.js +0 -715
  874. package/dist/manifest-registry-DAd0SRAP.js +0 -1329
  875. package/dist/matrix-BI0DBBrG.js +0 -1495
  876. package/dist/matrix-D2JoHzb4.d.ts +0 -68
  877. package/dist/matrix-DiABGjJR.js +0 -1269
  878. package/dist/mcp-cli-BOyn_DLL.js +0 -87
  879. package/dist/media-understanding.runtime-DjUa7Dka.js +0 -116
  880. package/dist/memory-cli-CJd_vl-Y.js +0 -111
  881. package/dist/memory-search-CEEItIFR.js +0 -17
  882. package/dist/memory-search-Cv1SBrn7.js +0 -204
  883. package/dist/method-scopes-CQE7-bZ-.js +0 -2452
  884. package/dist/model-auth-markers-BFoM4IPf.d.ts +0 -20
  885. package/dist/model-picker-D6_89XHg.js +0 -112
  886. package/dist/model-picker-Svaw-APs.js +0 -390
  887. package/dist/model-picker.runtime-Chi9nV7A.js +0 -125
  888. package/dist/model-selection-hL8i1Jbs.js +0 -653
  889. package/dist/model-suppression.runtime-DjWJZ0X-.js +0 -116
  890. package/dist/models-7qj1dG_W.js +0 -118
  891. package/dist/models-BPOB_xJF.js +0 -2514
  892. package/dist/models-cli-DdlOVUjS.js +0 -309
  893. package/dist/models-config-CBqUS-jX.js +0 -111
  894. package/dist/models-config.providers.discovery-Dc905FWG.d.ts +0 -18
  895. package/dist/moldclaw-root-D6PbhbZk.js +0 -88
  896. package/dist/monitor-BPYhkEqF.js +0 -782
  897. package/dist/monitor-BuTcQ24j.js +0 -3468
  898. package/dist/monitor-CuXvNhFh.js +0 -113
  899. package/dist/monitor-D-TqSIHF.js +0 -6823
  900. package/dist/monitor-DRSgo9u2.js +0 -3076
  901. package/dist/monitor-DcHch39z.js +0 -772
  902. package/dist/monitor-DsHBMrXp.js +0 -115
  903. package/dist/monitor-shared-CL8T4gt1.js +0 -444
  904. package/dist/msteams-7FMwTvQG.js +0 -852
  905. package/dist/node-cli-BCjaSCZM.js +0 -2503
  906. package/dist/node-resolve-D5Hvcgyx.js +0 -835
  907. package/dist/nodes-cli-Dd_SNbkt.js +0 -1380
  908. package/dist/nostr-DBTFTxKs.js +0 -8744
  909. package/dist/nostr-DLqaIuZx.d.ts +0 -7
  910. package/dist/npm-resolution-CYfb3MHG.js +0 -60
  911. package/dist/oauth-env-zPt5RywA.js +0 -10
  912. package/dist/onboard-BEFQQeig.js +0 -25
  913. package/dist/onboard-CJHNyxJh.js +0 -48
  914. package/dist/onboard-D_3UeLEN.js +0 -589
  915. package/dist/onboard-channels-B_JL0Djc.js +0 -1241
  916. package/dist/onboard-channels-CqZzHt2C.js +0 -205
  917. package/dist/onboard-custom-CER3Ggbq.js +0 -571
  918. package/dist/onboard-custom-bNRdGECb.js +0 -114
  919. package/dist/onboard-helpers-BK0Hsb7Y.js +0 -335
  920. package/dist/onboard-helpers-CXZ5RPoR.js +0 -113
  921. package/dist/onboard-hooks-1NsxEDjH.js +0 -72
  922. package/dist/onboard-remote-DuKhC_7W.js +0 -117
  923. package/dist/onboard-remote-OwRcDuB3.js +0 -181
  924. package/dist/onboard-search-Cy8dOq2W.js +0 -302
  925. package/dist/onboard-skills-D5phRa6r.js +0 -117
  926. package/dist/onboard-skills-c9qWCNe9.js +0 -133
  927. package/dist/outbound-media-CXKqTh2X.d.ts +0 -11
  928. package/dist/outbound-media-DYRO2vTD.js +0 -11
  929. package/dist/pairing-access-BwJu1mkk.d.ts +0 -21
  930. package/dist/pairing-cli-BOnv0TYn.js +0 -217
  931. package/dist/perplexity-EZwC3y2b.js +0 -24
  932. package/dist/persistent-dedupe-hNES5tS1.d.ts +0 -26
  933. package/dist/pi-model-discovery-runtime-BToY3A6K.js +0 -111
  934. package/dist/pi-tools.before-tool-call.runtime-D_acPtld.js +0 -381
  935. package/dist/plugin-install-CgJpSjYd.js +0 -184
  936. package/dist/plugin-install-Cl1A4EF6.js +0 -117
  937. package/dist/plugin-install-plan-Dc2Z4DeU.js +0 -49
  938. package/dist/plugin-registry-B1UaWrQD.js +0 -49
  939. package/dist/plugin-registry-Cy8biwnn.js +0 -113
  940. package/dist/plugins-CXwvg50F.js +0 -111
  941. package/dist/plugins-cli-Uvzp2aYV.js +0 -917
  942. package/dist/policy-DsMBbEe7.js +0 -143
  943. package/dist/preflight-audio.runtime-hWsZIYvc.js +0 -116
  944. package/dist/probe-CNsSf1Uf.js +0 -6329
  945. package/dist/probe-CqOIrPhb.js +0 -47
  946. package/dist/probe-DH6gDw-h.js +0 -129
  947. package/dist/probe-DM16PLf4.js +0 -21
  948. package/dist/probe-DvAEEWYr.js +0 -1793
  949. package/dist/probe-auth-COfgCble.js +0 -48
  950. package/dist/probe-auth-I_5TX1Eh.js +0 -40
  951. package/dist/program-Dz80sgTU.js +0 -253
  952. package/dist/prompt-select-styled-wQehwFxK.js +0 -2673
  953. package/dist/provider-api-key-auth.runtime-BR9GU4ya.js +0 -121
  954. package/dist/provider-auth-choice-CdhA84kr.js +0 -126
  955. package/dist/provider-auth-choice-helpers-kabp_0zA.js +0 -48
  956. package/dist/provider-auth-choice-preference-se3zAM_2.js +0 -189
  957. package/dist/provider-auth-choice.runtime-BMc8-xNQ.js +0 -123
  958. package/dist/provider-auth-choices-CYsCViGi.js +0 -57
  959. package/dist/provider-auth-guidance-CMjUWlNf.js +0 -34
  960. package/dist/provider-auth-result-5xgWoVGi.d.ts +0 -18
  961. package/dist/provider-models-BCId_Lfu.js +0 -2113
  962. package/dist/provider-models-D-eFl9oH.d.ts +0 -867
  963. package/dist/provider-ollama-setup-B6XJZ0So.js +0 -314
  964. package/dist/provider-ollama-setup-BF1vhob8.d.ts +0 -32
  965. package/dist/provider-onboard-BjXHP3IZ.d.ts +0 -40
  966. package/dist/provider-onboard-Ca0TaNud.js +0 -139
  967. package/dist/provider-runtime.runtime-DwwkHw_7.js +0 -111
  968. package/dist/provider-self-hosted-setup-BEKLVGpj.js +0 -182
  969. package/dist/provider-self-hosted-setup-BQ5BIlpi.d.ts +0 -61
  970. package/dist/provider-stream-DrUD69ai.js +0 -512
  971. package/dist/provider-usage-BgKHCnjr.js +0 -111
  972. package/dist/provider-usage-D8EZpFz9.js +0 -633
  973. package/dist/provider-wizard-DMdb-zj_.js +0 -152
  974. package/dist/push-apns-BPH6d4VV.js +0 -1038
  975. package/dist/pw-ai-DttfldtL.js +0 -1867
  976. package/dist/qmd-manager-CybcDUfk.js +0 -1570
  977. package/dist/qr-cli-8NcmJ8Ft.js +0 -369
  978. package/dist/qr-cli-DWe0Our3.js +0 -113
  979. package/dist/reactions-D6N0LR16.js +0 -281
  980. package/dist/read-only-account-inspect.discord.runtime-CqUWTRfl.js +0 -116
  981. package/dist/read-only-account-inspect.slack.runtime-9-jpln3q.js +0 -116
  982. package/dist/read-only-account-inspect.telegram.runtime-EKPI1D7n.js +0 -116
  983. package/dist/redact-snapshot-DwJEIVk9.js +0 -2663
  984. package/dist/register.agent-D3YdDirP.js +0 -439
  985. package/dist/register.backup-dR27qCuo.js +0 -625
  986. package/dist/register.configure-BjFhkkka.js +0 -252
  987. package/dist/register.maintenance-DiMQJIOa.js +0 -574
  988. package/dist/register.message-CdZsKYH1.js +0 -709
  989. package/dist/register.onboard-B0rV1eaO.js +0 -192
  990. package/dist/register.setup-wKMvohzo.js +0 -212
  991. package/dist/register.status-health-sessions-BJ68m6pt.js +0 -498
  992. package/dist/register.subclis-CnnrWt2a.js +0 -315
  993. package/dist/register.subclis-lSvTkC6z.js +0 -13
  994. package/dist/replies-BABt9b48.js +0 -110
  995. package/dist/resolve-channels-BqZFl2Ux.js +0 -262
  996. package/dist/resolve-channels-DjQLXb7B.js +0 -226
  997. package/dist/resolve-route-CSHDsa_m.js +0 -538
  998. package/dist/resolve-users-BG6HaSR5.js +0 -143
  999. package/dist/root-help-ohmaCyC_.js +0 -32
  1000. package/dist/routes-4k2kpvoT.js +0 -7097
  1001. package/dist/rpc-Cnwn4Q6L.js +0 -67
  1002. package/dist/run-main-VYlacKA0.js +0 -424
  1003. package/dist/runtime-Cy8pqYUB.d.ts +0 -26
  1004. package/dist/runtime-discord-ops.runtime-DafrU-rI.js +0 -9078
  1005. package/dist/runtime-slack-ops.runtime-CdXBKXwd.js +0 -4556
  1006. package/dist/runtime-telegram-ops.runtime-B12sF7gE.js +0 -133
  1007. package/dist/runtime-whatsapp-login.runtime-CqEudH37.js +0 -114
  1008. package/dist/runtime-whatsapp-outbound.runtime-D5m2qyn-.js +0 -117
  1009. package/dist/sandbox-cli-CHJiEWXB.js +0 -535
  1010. package/dist/search-manager-BtNC3-i_.js +0 -16
  1011. package/dist/search-manager-C7J7B3_a.js +0 -386
  1012. package/dist/secrets-cli-C6yIWBbN.js +0 -2070
  1013. package/dist/security-cli-BVu9BkjD.js +0 -575
  1014. package/dist/send-BSreC7rr.js +0 -631
  1015. package/dist/send-BsLHQG_B.js +0 -1025
  1016. package/dist/send-BuNhp8PH.js +0 -283
  1017. package/dist/send-DOCswVar.js +0 -100
  1018. package/dist/send-Dl0LLErk.js +0 -629
  1019. package/dist/server-node-events-Bq2067EG.js +0 -506
  1020. package/dist/server-y38L7N5H.js +0 -107
  1021. package/dist/sessions-BV8gXURR.js +0 -112
  1022. package/dist/sessions-dl1Kc-Ci.js +0 -218
  1023. package/dist/setup-DGszQH0_.js +0 -387
  1024. package/dist/setup-DR5rRw9y.d.ts +0 -37
  1025. package/dist/setup-binary-C17YnmA8.js +0 -406
  1026. package/dist/setup-browser-CPx-nEsr.js +0 -70
  1027. package/dist/setup-core-BByHN1ME.js +0 -143
  1028. package/dist/setup-core-C0KPlBmL.js +0 -47
  1029. package/dist/setup-core-Cq37G6of.js +0 -166
  1030. package/dist/setup-core-uO84_Y75.js +0 -205
  1031. package/dist/setup-surface-BEMi7Rmb.js +0 -490
  1032. package/dist/setup-wizard-helpers-BtuGx_gN.d.ts +0 -203
  1033. package/dist/setup.finalize-BzPBa8zW.js +0 -522
  1034. package/dist/setup.gateway-config-DdwkF-8e.js +0 -343
  1035. package/dist/shared-BCw4SKjB.js +0 -96
  1036. package/dist/shared-CjNzsULP.js +0 -75
  1037. package/dist/shared-Cu1BE7ZE.js +0 -298
  1038. package/dist/shared-DSClmyUn.js +0 -182
  1039. package/dist/shared-DyJdGH6y.js +0 -102
  1040. package/dist/signal-Dyv4NZsB.js +0 -114
  1041. package/dist/skills-CbB5b27M.js +0 -853
  1042. package/dist/skills-CnfI7Szw.js +0 -20
  1043. package/dist/skills-cli-CavB1f_3.js +0 -292
  1044. package/dist/skills-install-B1OBdgd0.js +0 -763
  1045. package/dist/skills-status-B3gAmIbW.js +0 -169
  1046. package/dist/skills-status-DrHhFgU9.js +0 -21
  1047. package/dist/slack-BRzqnoAz.js +0 -114
  1048. package/dist/slash-commands.runtime-BK88kgds.js +0 -128
  1049. package/dist/slash-dispatch.runtime-COGywwJE.js +0 -141
  1050. package/dist/slash-skill-commands.runtime-Ti4brxgh.js +0 -116
  1051. package/dist/src-DUR6OQxI.js +0 -1701
  1052. package/dist/status-C6dgQY9a.js +0 -131
  1053. package/dist/status-CNK0Q7QH.js +0 -606
  1054. package/dist/status-DBcX0DSC.js +0 -43
  1055. package/dist/status-DKgFgbwv.js +0 -1599
  1056. package/dist/status-Wn5lhNAc.js +0 -126
  1057. package/dist/status-json-D2EkWqAl.js +0 -288
  1058. package/dist/status.link-channel-D3ULIdEa.js +0 -143
  1059. package/dist/status.scan.deps.runtime-BsjWTAm4.js +0 -126
  1060. package/dist/status.scan.runtime-D4HbzROD.js +0 -119
  1061. package/dist/status.summary-C3YxPrDK.js +0 -592
  1062. package/dist/status.summary.runtime-DAkXPSaK.js +0 -118
  1063. package/dist/status.update-B4NnN9P1.js +0 -77
  1064. package/dist/subagent-orphan-recovery-QiQEBv36.js +0 -307
  1065. package/dist/subagent-registry-runtime-BJatPQFK.js +0 -111
  1066. package/dist/subscription-BhZORXN9.js +0 -100
  1067. package/dist/subscription-QEUjQRMv.js +0 -33
  1068. package/dist/subscription-cli-HrULlAgc.js +0 -134
  1069. package/dist/synology-chat-DB76GWMN.js +0 -297
  1070. package/dist/system-cli-D8jDwWuL.js +0 -94
  1071. package/dist/telegram-BHiiqKkQ.js +0 -114
  1072. package/dist/text-chunking-Baonm9Lu.js +0 -84
  1073. package/dist/text-chunking-Y3dPBOuZ.d.ts +0 -79
  1074. package/dist/tlon-DLESxNgD.js +0 -433
  1075. package/dist/tui-C75zi2Cl.js +0 -3834
  1076. package/dist/tui-cli-DFwx5e6i.js +0 -137
  1077. package/dist/types-BBJ3Qz7j.d.ts +0 -45
  1078. package/dist/types-Ckufs_BY.d.ts +0 -22692
  1079. package/dist/types.base-Cw0-zIvE.d.ts +0 -188
  1080. package/dist/ui-B55NOIB6.js +0 -31
  1081. package/dist/update--ojavYQ4.js +0 -1036
  1082. package/dist/update-cli-Cvj5aWYM.js +0 -1503
  1083. package/dist/update-offset-store-upatuWwX.js +0 -112
  1084. package/dist/update-runner-DHkY_-76.js +0 -1496
  1085. package/dist/upsert-with-lock-C171GLaR.js +0 -33
  1086. package/dist/usage-N3bxnbmt.js +0 -115
  1087. package/dist/web-RdvT7gKa.js +0 -112
  1088. package/dist/web-shared-HSGD3yGt.d.ts +0 -45
  1089. package/dist/webhook-request-guards-CosLyl01.d.ts +0 -76
  1090. package/dist/webhook-targets-Bfnag-du.js +0 -181
  1091. package/dist/webhook-targets-Di17rt8e.d.ts +0 -106
  1092. package/dist/webhooks-cli-ZpnXrq7G.js +0 -350
  1093. package/dist/whatsapp-DNTAyZHt.js +0 -114
  1094. package/dist/whatsapp-actions-o1zKQzKZ.js +0 -167
  1095. package/dist/workspace-CpWi5wPr.js +0 -479
  1096. package/dist/workspace-Ii7aRS7c.js +0 -289
  1097. package/dist/workspace-dirs-x10McA9t.js +0 -2003
  1098. package/dist/zalo-BN3VCrRY.d.ts +0 -9
  1099. package/dist/zalo-zm_bYCKg.js +0 -415
  1100. package/dist/zalouser-CvVEUvc5.js +0 -30911
  1101. /package/dist/{account-id-B3YSn4hl.d.ts → account-id-B8ce6G_4.d.ts} +0 -0
  1102. /package/dist/{acpx-CnNv70m2.d.ts → acpx-Ci50I9T2.d.ts} +0 -0
  1103. /package/dist/{agent-media-payload-DE2pEcsz.d.ts → agent-media-payload-en-gS5p6.d.ts} +0 -0
  1104. /package/dist/{allow-from-DPpHnT2A.d.ts → allow-from-cMeQ47Ot.d.ts} +0 -0
  1105. /package/dist/{allowlist-resolution-CLFiZ6nE.d.ts → allowlist-resolution-DoAWbfXV.d.ts} +0 -0
  1106. /package/dist/{bluebubbles-Duhu-Jer.d.ts → bluebubbles-C6yYmUl0.d.ts} +0 -0
  1107. /package/dist/{boolean-param-BhFjB3gp.d.ts → boolean-param-CdO2TFTk.d.ts} +0 -0
  1108. /package/dist/{channel-config-schema-DnnVMdjR.d.ts → channel-config-schema-Chp38wel.d.ts} +0 -0
  1109. /package/dist/{channel-policy-Baq-Z06b.d.ts → channel-policy-g2h6AbYQ.d.ts} +0 -0
  1110. /package/dist/{chat-type-DpiBgwuG.d.ts → chat-type-BLt59pPT.d.ts} +0 -0
  1111. /package/dist/{command-format-vi4xq8e8.d.ts → command-format-BDJC05Jp.d.ts} +0 -0
  1112. /package/dist/{diffs-DK7fVSDo.d.ts → diffs-D_iNKCyn.d.ts} +0 -0
  1113. /package/dist/{directory-runtime-BTLPaysA.d.ts → directory-runtime-DhMex6HY.d.ts} +0 -0
  1114. /package/dist/{exec-C01wtBHu.d.ts → exec-pjfUY4KM.d.ts} +0 -0
  1115. /package/dist/{gaxios-fetch-compat-wZ38b3w3.js → gaxios-fetch-compat-B_vtINdV.js} +0 -0
  1116. /package/dist/{history-CwXuP2TW.d.ts → history-aqSS5VGQ.d.ts} +0 -0
  1117. /package/dist/{inbound-envelope-SggrBs9m.d.ts → inbound-envelope-C5hWuZod.d.ts} +0 -0
  1118. /package/dist/{index-apAZHsDo.d.ts → index-DXVQFYGX.d.ts} +0 -0
  1119. /package/dist/{json-store-r75IZGk9.d.ts → json-store-UnqQ5aV3.d.ts} +0 -0
  1120. /package/dist/{keyed-async-queue-DHIr7yNe.d.ts → keyed-async-queue-guucpLw3.d.ts} +0 -0
  1121. /package/dist/{links-HeQ3r_L0.d.ts → links-Bar0meEK.d.ts} +0 -0
  1122. /package/dist/{markdown-to-line-CDb4Jy3V.d.ts → markdown-to-line-D8uH_KOj.d.ts} +0 -0
  1123. /package/dist/{mattermost-DtCsxpgg.d.ts → mattermost-xl7jAFJL.d.ts} +0 -0
  1124. /package/dist/{net-BATPDwdQ.d.ts → net-rGOKGds6.d.ts} +0 -0
  1125. /package/dist/{nextcloud-talk-Bb2wHOwp.d.ts → nextcloud-talk-De2CZ9dV.d.ts} +0 -0
  1126. /package/dist/{oauth-utils-u567CLT0.d.ts → oauth-utils-DzN1AlEH.d.ts} +0 -0
  1127. /package/dist/{parse-finite-number-l3tNlrZh.d.ts → parse-finite-number-odgyqhi0.d.ts} +0 -0
  1128. /package/dist/{provider-usage.types-C6061OVN.d.ts → provider-usage.types-EDE9o-H_.d.ts} +0 -0
  1129. /package/dist/{reply-history-BDsFnZFl.d.ts → reply-history-CVuU31xe.d.ts} +0 -0
  1130. /package/dist/{reply-payload-CCvM4W9u.d.ts → reply-payload-CHkpBYwL.d.ts} +0 -0
  1131. /package/dist/{request-url-C54l4-xC.d.ts → request-url-DHisbiHY.d.ts} +0 -0
  1132. /package/dist/{run-command-D3RqWcHu.d.ts → run-command-y0Cndsb1.d.ts} +0 -0
  1133. /package/dist/{secret-input-schema-BLBt-NAP.d.ts → secret-input-schema-b1vpYDQN.d.ts} +0 -0
  1134. /package/dist/{session-key-BQ2-bR-9.d.ts → session-key-DTHQl57f.d.ts} +0 -0
  1135. /package/dist/{ssh-config-C4mcH9Ly.js → ssh-config-hEHBfU2_.js} +0 -0
  1136. /package/dist/{testing-DLkhGsoz.d.ts → testing-DszuZXgK.d.ts} +0 -0
  1137. /package/dist/{thinking-DRkjX18p.d.ts → thinking-IwXTGSeT.d.ts} +0 -0
  1138. /package/dist/{tool-send-CMMD1uDu.d.ts → tool-send-DWHRmKpz.d.ts} +0 -0
  1139. /package/dist/{vllm-defaults-CcGuf4hL.d.ts → vllm-defaults-CrxZgE6-.d.ts} +0 -0
  1140. /package/dist/{wait-Daog8bxM.d.ts → wait-wDWw_MTI.d.ts} +0 -0
  1141. /package/dist/{webhook-memory-guards-C5MrExwT.d.ts → webhook-memory-guards-DreORuJy.d.ts} +0 -0
  1142. /package/dist/{windows-spawn-j2l-dqu8.d.ts → windows-spawn-BIzH92x2.d.ts} +0 -0
  1143. /package/dist/{zod-schema.agent-runtime-krMrBnIn.d.ts → zod-schema.agent-runtime-CP2rmis3.d.ts} +0 -0
  1144. /package/dist/{zod-schema.core-BNDieZDZ.d.ts → zod-schema.core-Foi1tYwi.d.ts} +0 -0
@@ -1,1038 +0,0 @@
1
- import { n as redactSensitiveText, t as getDefaultRedactPatterns } from "./redact-fatrROh9.js";
2
- import { _ as resolveStateDir } from "./paths-D6AgsMTU.js";
3
- import { r as isVerbose } from "./globals-DESrFYmC.js";
4
- import { f as shouldLogSubsystemToConsole, t as createSubsystemLogger } from "./subsystem-CPmDTJ2P.js";
5
- import { al as sniffMimeFromBase64 } from "./auth-profiles-1kPLbBwI.js";
6
- import { S as parseAgentSessionKey } from "./session-key-UoG7Kfw5.js";
7
- import { G as estimateBase64DecodedBytes } from "./provider-web-search-CcUC9ktE.js";
8
- import { n as readJsonFile, r as writeJsonAtomic, t as createAsyncLock } from "./json-files-B9YQFF4Z.js";
9
- import { a as signDevicePayload, n as loadOrCreateDeviceIdentity } from "./device-identity-CRfhC3_s.js";
10
- import { URL } from "node:url";
11
- import path from "node:path";
12
- import chalk from "chalk";
13
- import fs from "node:fs/promises";
14
- import { createHash, createPrivateKey, sign } from "node:crypto";
15
- import http2 from "node:http2";
16
- //#region src/gateway/ws-logging.ts
17
- let gatewayWsLogStyle = "auto";
18
- function setGatewayWsLogStyle(style) {
19
- gatewayWsLogStyle = style;
20
- }
21
- function getGatewayWsLogStyle() {
22
- return gatewayWsLogStyle;
23
- }
24
- //#endregion
25
- //#region src/gateway/ws-log.ts
26
- const LOG_VALUE_LIMIT = 240;
27
- const UUID_RE = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;
28
- const WS_LOG_REDACT_OPTIONS = {
29
- mode: "tools",
30
- patterns: getDefaultRedactPatterns()
31
- };
32
- const wsInflightCompact = /* @__PURE__ */ new Map();
33
- let wsLastCompactConnId;
34
- const wsInflightOptimized = /* @__PURE__ */ new Map();
35
- const wsInflightSince = /* @__PURE__ */ new Map();
36
- const wsLog = createSubsystemLogger("gateway/ws");
37
- const WS_META_SKIP_KEYS = new Set([
38
- "connId",
39
- "id",
40
- "method",
41
- "ok",
42
- "event"
43
- ]);
44
- function collectWsRestMeta(meta) {
45
- const restMeta = [];
46
- if (!meta) return restMeta;
47
- for (const [key, value] of Object.entries(meta)) {
48
- if (value === void 0) continue;
49
- if (WS_META_SKIP_KEYS.has(key)) continue;
50
- restMeta.push(`${chalk.dim(key)}=${formatForLog(value)}`);
51
- }
52
- return restMeta;
53
- }
54
- function buildWsHeadline(params) {
55
- if ((params.kind === "req" || params.kind === "res") && params.method) return chalk.bold(params.method);
56
- if (params.kind === "event" && params.event) return chalk.bold(params.event);
57
- }
58
- function buildWsStatusToken(kind, ok) {
59
- if (kind !== "res" || ok === void 0) return;
60
- return ok ? chalk.greenBright("✓") : chalk.redBright("✗");
61
- }
62
- function logWsInfoLine(params) {
63
- const tokens = [
64
- params.prefix,
65
- params.statusToken,
66
- params.headline,
67
- params.durationToken,
68
- ...params.restMeta,
69
- ...params.trailing
70
- ].filter((t) => Boolean(t));
71
- wsLog.info(tokens.join(" "));
72
- }
73
- function shouldLogWs() {
74
- return shouldLogSubsystemToConsole("gateway/ws");
75
- }
76
- function shortId(value) {
77
- const s = value.trim();
78
- if (UUID_RE.test(s)) return `${s.slice(0, 8)}…${s.slice(-4)}`;
79
- if (s.length <= 24) return s;
80
- return `${s.slice(0, 12)}…${s.slice(-4)}`;
81
- }
82
- function formatForLog(value) {
83
- try {
84
- if (value instanceof Error) {
85
- const parts = [];
86
- if (value.name) parts.push(value.name);
87
- if (value.message) parts.push(value.message);
88
- const code = "code" in value && (typeof value.code === "string" || typeof value.code === "number") ? String(value.code) : "";
89
- if (code) parts.push(`code=${code}`);
90
- const combined = parts.filter(Boolean).join(": ").trim();
91
- if (combined) return combined.length > LOG_VALUE_LIMIT ? `${combined.slice(0, LOG_VALUE_LIMIT)}...` : combined;
92
- }
93
- if (value && typeof value === "object") {
94
- const rec = value;
95
- if (typeof rec.message === "string" && rec.message.trim()) {
96
- const name = typeof rec.name === "string" ? rec.name.trim() : "";
97
- const code = typeof rec.code === "string" || typeof rec.code === "number" ? String(rec.code) : "";
98
- const parts = [name, rec.message.trim()].filter(Boolean);
99
- if (code) parts.push(`code=${code}`);
100
- const combined = parts.join(": ").trim();
101
- return combined.length > LOG_VALUE_LIMIT ? `${combined.slice(0, LOG_VALUE_LIMIT)}...` : combined;
102
- }
103
- }
104
- const str = typeof value === "string" || typeof value === "number" ? String(value) : JSON.stringify(value);
105
- if (!str) return "";
106
- const redacted = redactSensitiveText(str, WS_LOG_REDACT_OPTIONS);
107
- return redacted.length > LOG_VALUE_LIMIT ? `${redacted.slice(0, LOG_VALUE_LIMIT)}...` : redacted;
108
- } catch {
109
- return String(value);
110
- }
111
- }
112
- function compactPreview(input, maxLen = 160) {
113
- const oneLine = input.replace(/\s+/g, " ").trim();
114
- if (oneLine.length <= maxLen) return oneLine;
115
- return `${oneLine.slice(0, Math.max(0, maxLen - 1))}…`;
116
- }
117
- function summarizeAgentEventForWsLog(payload) {
118
- if (!payload || typeof payload !== "object") return {};
119
- const rec = payload;
120
- const runId = typeof rec.runId === "string" ? rec.runId : void 0;
121
- const stream = typeof rec.stream === "string" ? rec.stream : void 0;
122
- const seq = typeof rec.seq === "number" ? rec.seq : void 0;
123
- const sessionKey = typeof rec.sessionKey === "string" ? rec.sessionKey : void 0;
124
- const data = rec.data && typeof rec.data === "object" ? rec.data : void 0;
125
- const extra = {};
126
- if (runId) extra.run = shortId(runId);
127
- if (sessionKey) {
128
- const parsed = parseAgentSessionKey(sessionKey);
129
- if (parsed) {
130
- extra.agent = parsed.agentId;
131
- extra.session = parsed.rest;
132
- } else extra.session = sessionKey;
133
- }
134
- if (stream) extra.stream = stream;
135
- if (seq !== void 0) extra.aseq = seq;
136
- if (!data) return extra;
137
- if (stream === "assistant") {
138
- const text = typeof data.text === "string" ? data.text : void 0;
139
- if (text?.trim()) extra.text = compactPreview(text);
140
- const mediaUrls = Array.isArray(data.mediaUrls) ? data.mediaUrls : void 0;
141
- if (mediaUrls && mediaUrls.length > 0) extra.media = mediaUrls.length;
142
- return extra;
143
- }
144
- if (stream === "tool") {
145
- const phase = typeof data.phase === "string" ? data.phase : void 0;
146
- const name = typeof data.name === "string" ? data.name : void 0;
147
- if (phase || name) extra.tool = `${phase ?? "?"}:${name ?? "?"}`;
148
- const toolCallId = typeof data.toolCallId === "string" ? data.toolCallId : void 0;
149
- if (toolCallId) extra.call = shortId(toolCallId);
150
- const meta = typeof data.meta === "string" ? data.meta : void 0;
151
- if (meta?.trim()) extra.meta = meta;
152
- if (typeof data.isError === "boolean") extra.err = data.isError;
153
- return extra;
154
- }
155
- if (stream === "lifecycle") {
156
- const phase = typeof data.phase === "string" ? data.phase : void 0;
157
- if (phase) extra.phase = phase;
158
- if (typeof data.aborted === "boolean") extra.aborted = data.aborted;
159
- const error = typeof data.error === "string" ? data.error : void 0;
160
- if (error?.trim()) extra.error = compactPreview(error, 120);
161
- return extra;
162
- }
163
- const reason = typeof data.reason === "string" ? data.reason : void 0;
164
- if (reason?.trim()) extra.reason = reason;
165
- return extra;
166
- }
167
- function logWs(direction, kind, meta) {
168
- if (!shouldLogSubsystemToConsole("gateway/ws")) return;
169
- const style = getGatewayWsLogStyle();
170
- if (!isVerbose()) {
171
- logWsOptimized(direction, kind, meta);
172
- return;
173
- }
174
- if (style === "compact" || style === "auto") {
175
- logWsCompact(direction, kind, meta);
176
- return;
177
- }
178
- const now = Date.now();
179
- const connId = typeof meta?.connId === "string" ? meta.connId : void 0;
180
- const id = typeof meta?.id === "string" ? meta.id : void 0;
181
- const method = typeof meta?.method === "string" ? meta.method : void 0;
182
- const ok = typeof meta?.ok === "boolean" ? meta.ok : void 0;
183
- const event = typeof meta?.event === "string" ? meta.event : void 0;
184
- const inflightKey = connId && id ? `${connId}:${id}` : void 0;
185
- if (direction === "in" && kind === "req" && inflightKey) wsInflightSince.set(inflightKey, now);
186
- const durationMs = direction === "out" && kind === "res" && inflightKey ? (() => {
187
- const startedAt = wsInflightSince.get(inflightKey);
188
- if (startedAt === void 0) return;
189
- wsInflightSince.delete(inflightKey);
190
- return now - startedAt;
191
- })() : void 0;
192
- const dirArrow = direction === "in" ? "←" : "→";
193
- const prefix = `${(direction === "in" ? chalk.greenBright : chalk.cyanBright)(dirArrow)} ${chalk.bold(kind)}`;
194
- const headline = buildWsHeadline({
195
- kind,
196
- method,
197
- event
198
- });
199
- const statusToken = buildWsStatusToken(kind, ok);
200
- const durationToken = typeof durationMs === "number" ? chalk.dim(`${durationMs}ms`) : void 0;
201
- const restMeta = collectWsRestMeta(meta);
202
- const trailing = [];
203
- if (connId) trailing.push(`${chalk.dim("conn")}=${chalk.gray(shortId(connId))}`);
204
- if (id) trailing.push(`${chalk.dim("id")}=${chalk.gray(shortId(id))}`);
205
- logWsInfoLine({
206
- prefix,
207
- statusToken,
208
- headline,
209
- durationToken,
210
- restMeta,
211
- trailing
212
- });
213
- }
214
- function logWsOptimized(direction, kind, meta) {
215
- const connId = typeof meta?.connId === "string" ? meta.connId : void 0;
216
- const id = typeof meta?.id === "string" ? meta.id : void 0;
217
- const ok = typeof meta?.ok === "boolean" ? meta.ok : void 0;
218
- const method = typeof meta?.method === "string" ? meta.method : void 0;
219
- const inflightKey = connId && id ? `${connId}:${id}` : void 0;
220
- if (direction === "in" && kind === "req" && inflightKey) {
221
- wsInflightOptimized.set(inflightKey, Date.now());
222
- if (wsInflightOptimized.size > 2e3) wsInflightOptimized.clear();
223
- return;
224
- }
225
- if (kind === "parse-error") {
226
- const errorMsg = typeof meta?.error === "string" ? formatForLog(meta.error) : void 0;
227
- wsLog.warn([
228
- `${chalk.redBright("✗")} ${chalk.bold("parse-error")}`,
229
- errorMsg ? `${chalk.dim("error")}=${errorMsg}` : void 0,
230
- `${chalk.dim("conn")}=${chalk.gray(shortId(connId ?? "?"))}`
231
- ].filter((t) => Boolean(t)).join(" "));
232
- return;
233
- }
234
- if (direction !== "out" || kind !== "res") return;
235
- const startedAt = inflightKey ? wsInflightOptimized.get(inflightKey) : void 0;
236
- if (inflightKey) wsInflightOptimized.delete(inflightKey);
237
- const durationMs = typeof startedAt === "number" ? Date.now() - startedAt : void 0;
238
- if (!(ok === false || typeof durationMs === "number" && durationMs >= 50)) return;
239
- const statusToken = buildWsStatusToken("res", ok);
240
- const durationToken = typeof durationMs === "number" ? chalk.dim(`${durationMs}ms`) : void 0;
241
- const restMeta = collectWsRestMeta(meta);
242
- logWsInfoLine({
243
- prefix: `${chalk.yellowBright("⇄")} ${chalk.bold("res")}`,
244
- statusToken,
245
- headline: method ? chalk.bold(method) : void 0,
246
- durationToken,
247
- restMeta,
248
- trailing: [connId ? `${chalk.dim("conn")}=${chalk.gray(shortId(connId))}` : "", id ? `${chalk.dim("id")}=${chalk.gray(shortId(id))}` : ""].filter(Boolean)
249
- });
250
- }
251
- function logWsCompact(direction, kind, meta) {
252
- const now = Date.now();
253
- const connId = typeof meta?.connId === "string" ? meta.connId : void 0;
254
- const id = typeof meta?.id === "string" ? meta.id : void 0;
255
- const method = typeof meta?.method === "string" ? meta.method : void 0;
256
- const ok = typeof meta?.ok === "boolean" ? meta.ok : void 0;
257
- const inflightKey = connId && id ? `${connId}:${id}` : void 0;
258
- if (kind === "req" && direction === "in" && inflightKey) {
259
- wsInflightCompact.set(inflightKey, {
260
- ts: now,
261
- method,
262
- meta
263
- });
264
- return;
265
- }
266
- const compactArrow = (() => {
267
- if (kind === "req" || kind === "res") return "⇄";
268
- return direction === "in" ? "←" : "→";
269
- })();
270
- const prefix = `${(kind === "req" || kind === "res" ? chalk.yellowBright : direction === "in" ? chalk.greenBright : chalk.cyanBright)(compactArrow)} ${chalk.bold(kind)}`;
271
- const statusToken = buildWsStatusToken(kind, ok);
272
- const startedAt = kind === "res" && direction === "out" && inflightKey ? wsInflightCompact.get(inflightKey)?.ts : void 0;
273
- if (kind === "res" && direction === "out" && inflightKey) wsInflightCompact.delete(inflightKey);
274
- const durationToken = typeof startedAt === "number" ? chalk.dim(`${now - startedAt}ms`) : void 0;
275
- const headline = buildWsHeadline({
276
- kind,
277
- method,
278
- event: typeof meta?.event === "string" ? meta.event : void 0
279
- });
280
- const restMeta = collectWsRestMeta(meta);
281
- const trailing = [];
282
- if (connId && connId !== wsLastCompactConnId) {
283
- trailing.push(`${chalk.dim("conn")}=${chalk.gray(shortId(connId))}`);
284
- wsLastCompactConnId = connId;
285
- }
286
- if (id) trailing.push(`${chalk.dim("id")}=${chalk.gray(shortId(id))}`);
287
- logWsInfoLine({
288
- prefix,
289
- statusToken,
290
- headline,
291
- durationToken,
292
- restMeta,
293
- trailing
294
- });
295
- }
296
- //#endregion
297
- //#region src/gateway/chat-attachments.ts
298
- function normalizeMime(mime) {
299
- if (!mime) return;
300
- return mime.split(";")[0]?.trim().toLowerCase() || void 0;
301
- }
302
- function isImageMime(mime) {
303
- return typeof mime === "string" && mime.startsWith("image/");
304
- }
305
- function isValidBase64(value) {
306
- return value.length > 0 && value.length % 4 === 0 && /^[A-Za-z0-9+/]+={0,2}$/.test(value);
307
- }
308
- function normalizeAttachment(att, idx, opts) {
309
- const mime = att.mimeType ?? "";
310
- const content = att.content;
311
- const label = att.fileName || att.type || `attachment-${idx + 1}`;
312
- if (typeof content !== "string") throw new Error(`attachment ${label}: content must be base64 string`);
313
- if (opts.requireImageMime && !mime.startsWith("image/")) throw new Error(`attachment ${label}: only image/* supported`);
314
- let base64 = content.trim();
315
- if (opts.stripDataUrlPrefix) {
316
- const dataUrlMatch = /^data:[^;]+;base64,(.*)$/.exec(base64);
317
- if (dataUrlMatch) base64 = dataUrlMatch[1];
318
- }
319
- return {
320
- label,
321
- mime,
322
- base64
323
- };
324
- }
325
- function validateAttachmentBase64OrThrow(normalized, opts) {
326
- if (!isValidBase64(normalized.base64)) throw new Error(`attachment ${normalized.label}: invalid base64 content`);
327
- const sizeBytes = estimateBase64DecodedBytes(normalized.base64);
328
- if (sizeBytes <= 0 || sizeBytes > opts.maxBytes) throw new Error(`attachment ${normalized.label}: exceeds size limit (${sizeBytes} > ${opts.maxBytes} bytes)`);
329
- return sizeBytes;
330
- }
331
- /**
332
- * Parse attachments and extract images as structured content blocks.
333
- * Returns the message text and an array of image content blocks
334
- * compatible with Claude API's image format.
335
- */
336
- async function parseMessageWithAttachments(message, attachments, opts) {
337
- const maxBytes = opts?.maxBytes ?? 5e6;
338
- const log = opts?.log;
339
- if (!attachments || attachments.length === 0) return {
340
- message,
341
- images: []
342
- };
343
- const images = [];
344
- for (const [idx, att] of attachments.entries()) {
345
- if (!att) continue;
346
- const normalized = normalizeAttachment(att, idx, {
347
- stripDataUrlPrefix: true,
348
- requireImageMime: false
349
- });
350
- validateAttachmentBase64OrThrow(normalized, { maxBytes });
351
- const { base64: b64, label, mime } = normalized;
352
- const providedMime = normalizeMime(mime);
353
- const sniffedMime = normalizeMime(await sniffMimeFromBase64(b64));
354
- if (sniffedMime && !isImageMime(sniffedMime)) {
355
- log?.warn(`attachment ${label}: detected non-image (${sniffedMime}), dropping`);
356
- continue;
357
- }
358
- if (!sniffedMime && !isImageMime(providedMime)) {
359
- log?.warn(`attachment ${label}: unable to detect image mime type, dropping`);
360
- continue;
361
- }
362
- if (sniffedMime && providedMime && sniffedMime !== providedMime) log?.warn(`attachment ${label}: mime mismatch (${providedMime} -> ${sniffedMime}), using sniffed`);
363
- images.push({
364
- type: "image",
365
- data: b64,
366
- mimeType: sniffedMime ?? providedMime ?? mime
367
- });
368
- }
369
- return {
370
- message,
371
- images
372
- };
373
- }
374
- //#endregion
375
- //#region src/gateway/server-methods/attachment-normalize.ts
376
- function normalizeRpcAttachmentsToChatAttachments(attachments) {
377
- return attachments?.map((a) => ({
378
- type: typeof a?.type === "string" ? a.type : void 0,
379
- mimeType: typeof a?.mimeType === "string" ? a.mimeType : void 0,
380
- fileName: typeof a?.fileName === "string" ? a.fileName : void 0,
381
- content: typeof a?.content === "string" ? a.content : ArrayBuffer.isView(a?.content) ? Buffer.from(a.content.buffer, a.content.byteOffset, a.content.byteLength).toString("base64") : a?.content instanceof ArrayBuffer ? Buffer.from(a.content).toString("base64") : void 0
382
- })).filter((a) => a.content) ?? [];
383
- }
384
- //#endregion
385
- //#region src/infra/push-apns.relay.ts
386
- const DEFAULT_APNS_RELAY_TIMEOUT_MS = 1e4;
387
- const GATEWAY_DEVICE_ID_HEADER = "x-moldclaw-gateway-device-id";
388
- const GATEWAY_SIGNATURE_HEADER = "x-moldclaw-gateway-signature";
389
- const GATEWAY_SIGNED_AT_HEADER = "x-moldclaw-gateway-signed-at-ms";
390
- function normalizeNonEmptyString$1(value) {
391
- const trimmed = value?.trim() ?? "";
392
- return trimmed.length > 0 ? trimmed : null;
393
- }
394
- function normalizeTimeoutMs(value) {
395
- const raw = typeof value === "number" ? value : typeof value === "string" ? value.trim() : void 0;
396
- if (raw === void 0 || raw === "") return DEFAULT_APNS_RELAY_TIMEOUT_MS;
397
- const parsed = Number(raw);
398
- if (!Number.isFinite(parsed)) return DEFAULT_APNS_RELAY_TIMEOUT_MS;
399
- return Math.max(1e3, Math.trunc(parsed));
400
- }
401
- function readAllowHttp(value) {
402
- const normalized = value?.trim().toLowerCase();
403
- return normalized === "1" || normalized === "true" || normalized === "yes";
404
- }
405
- function isLoopbackRelayHostname(hostname) {
406
- const normalized = hostname.trim().toLowerCase();
407
- return normalized === "localhost" || normalized === "::1" || normalized === "[::1]" || /^127(?:\.\d{1,3}){3}$/.test(normalized);
408
- }
409
- function parseReason$1(value) {
410
- return typeof value === "string" && value.trim().length > 0 ? value.trim() : void 0;
411
- }
412
- function buildRelayGatewaySignaturePayload(params) {
413
- return [
414
- "moldclaw-relay-send-v1",
415
- params.gatewayDeviceId.trim(),
416
- String(Math.trunc(params.signedAtMs)),
417
- params.bodyJson
418
- ].join("\n");
419
- }
420
- function resolveApnsRelayConfigFromEnv(env = process.env, gatewayConfig) {
421
- const configuredRelay = gatewayConfig?.push?.apns?.relay;
422
- const envBaseUrl = normalizeNonEmptyString$1(env.MOLDCLAW_APNS_RELAY_BASE_URL);
423
- const configBaseUrl = normalizeNonEmptyString$1(configuredRelay?.baseUrl);
424
- const baseUrl = envBaseUrl ?? configBaseUrl;
425
- const baseUrlSource = envBaseUrl ? "MOLDCLAW_APNS_RELAY_BASE_URL" : "gateway.push.apns.relay.baseUrl";
426
- if (!baseUrl) return {
427
- ok: false,
428
- error: "APNs relay config missing: set gateway.push.apns.relay.baseUrl or MOLDCLAW_APNS_RELAY_BASE_URL"
429
- };
430
- try {
431
- const parsed = new URL(baseUrl);
432
- if (parsed.protocol !== "https:" && parsed.protocol !== "http:") throw new Error("unsupported protocol");
433
- if (!parsed.hostname) throw new Error("host required");
434
- if (parsed.protocol === "http:" && !readAllowHttp(env.MOLDCLAW_APNS_RELAY_ALLOW_HTTP)) throw new Error("http relay URLs require MOLDCLAW_APNS_RELAY_ALLOW_HTTP=true (development only)");
435
- if (parsed.protocol === "http:" && !isLoopbackRelayHostname(parsed.hostname)) throw new Error("http relay URLs are limited to loopback hosts");
436
- if (parsed.username || parsed.password) throw new Error("userinfo is not allowed");
437
- if (parsed.search || parsed.hash) throw new Error("query and fragment are not allowed");
438
- return {
439
- ok: true,
440
- value: {
441
- baseUrl: parsed.toString().replace(/\/+$/, ""),
442
- timeoutMs: normalizeTimeoutMs(env.MOLDCLAW_APNS_RELAY_TIMEOUT_MS ?? configuredRelay?.timeoutMs)
443
- }
444
- };
445
- } catch (err) {
446
- return {
447
- ok: false,
448
- error: `invalid ${baseUrlSource} (${baseUrl}): ${err instanceof Error ? err.message : String(err)}`
449
- };
450
- }
451
- }
452
- async function sendApnsRelayRequest(params) {
453
- const response = await fetch(`${params.relayConfig.baseUrl}/v1/push/send`, {
454
- method: "POST",
455
- redirect: "manual",
456
- headers: {
457
- authorization: `Bearer ${params.sendGrant}`,
458
- "content-type": "application/json",
459
- [GATEWAY_DEVICE_ID_HEADER]: params.gatewayDeviceId,
460
- [GATEWAY_SIGNATURE_HEADER]: params.signature,
461
- [GATEWAY_SIGNED_AT_HEADER]: String(params.signedAtMs)
462
- },
463
- body: params.bodyJson,
464
- signal: AbortSignal.timeout(params.relayConfig.timeoutMs)
465
- });
466
- if (response.status >= 300 && response.status < 400) return {
467
- ok: false,
468
- status: response.status,
469
- reason: "RelayRedirectNotAllowed",
470
- environment: "production"
471
- };
472
- let json = null;
473
- try {
474
- json = await response.json();
475
- } catch {
476
- json = null;
477
- }
478
- const body = json && typeof json === "object" && !Array.isArray(json) ? json : {};
479
- const status = typeof body.status === "number" && Number.isFinite(body.status) ? Math.trunc(body.status) : response.status;
480
- return {
481
- ok: typeof body.ok === "boolean" ? body.ok : response.ok && status >= 200 && status < 300,
482
- status,
483
- apnsId: parseReason$1(body.apnsId),
484
- reason: parseReason$1(body.reason),
485
- environment: "production",
486
- tokenSuffix: parseReason$1(body.tokenSuffix)
487
- };
488
- }
489
- async function sendApnsRelayPush(params) {
490
- const sender = params.requestSender ?? sendApnsRelayRequest;
491
- const gatewayIdentity = params.gatewayIdentity ?? loadOrCreateDeviceIdentity();
492
- const signedAtMs = Date.now();
493
- const bodyJson = JSON.stringify({
494
- relayHandle: params.relayHandle,
495
- pushType: params.pushType,
496
- priority: Number(params.priority),
497
- payload: params.payload
498
- });
499
- const signature = signDevicePayload(gatewayIdentity.privateKeyPem, buildRelayGatewaySignaturePayload({
500
- gatewayDeviceId: gatewayIdentity.deviceId,
501
- signedAtMs,
502
- bodyJson
503
- }));
504
- return await sender({
505
- relayConfig: params.relayConfig,
506
- sendGrant: params.sendGrant,
507
- relayHandle: params.relayHandle,
508
- gatewayDeviceId: gatewayIdentity.deviceId,
509
- signature,
510
- signedAtMs,
511
- bodyJson,
512
- pushType: params.pushType,
513
- priority: params.priority,
514
- payload: params.payload
515
- });
516
- }
517
- //#endregion
518
- //#region src/infra/push-apns.ts
519
- const APNS_STATE_FILENAME = "push/apns-registrations.json";
520
- const APNS_JWT_TTL_MS = 3e3 * 1e3;
521
- const DEFAULT_APNS_TIMEOUT_MS = 1e4;
522
- const MAX_NODE_ID_LENGTH = 256;
523
- const MAX_TOPIC_LENGTH = 255;
524
- const MAX_APNS_TOKEN_HEX_LENGTH = 512;
525
- const MAX_RELAY_IDENTIFIER_LENGTH = 256;
526
- const MAX_SEND_GRANT_LENGTH = 1024;
527
- const withLock = createAsyncLock();
528
- let cachedJwt = null;
529
- function resolveApnsRegistrationPath(baseDir) {
530
- const root = baseDir ?? resolveStateDir();
531
- return path.join(root, APNS_STATE_FILENAME);
532
- }
533
- function normalizeNodeId(value) {
534
- return value.trim();
535
- }
536
- function isValidNodeId(value) {
537
- return value.length > 0 && value.length <= MAX_NODE_ID_LENGTH;
538
- }
539
- function normalizeApnsToken(value) {
540
- return value.trim().replace(/[<>\s]/g, "").toLowerCase();
541
- }
542
- function normalizeRelayHandle(value) {
543
- return value.trim();
544
- }
545
- function normalizeInstallationId(value) {
546
- return value.trim();
547
- }
548
- function validateRelayIdentifier(value, fieldName, maxLength = MAX_RELAY_IDENTIFIER_LENGTH) {
549
- if (!value) throw new Error(`${fieldName} required`);
550
- if (value.length > maxLength) throw new Error(`${fieldName} too long`);
551
- if (/[^\x21-\x7e]/.test(value)) throw new Error(`${fieldName} invalid`);
552
- return value;
553
- }
554
- function normalizeTopic(value) {
555
- return value.trim();
556
- }
557
- function isValidTopic(value) {
558
- return value.length > 0 && value.length <= MAX_TOPIC_LENGTH;
559
- }
560
- function normalizeTokenDebugSuffix(value) {
561
- if (typeof value !== "string") return;
562
- const normalized = value.trim().toLowerCase().replace(/[^0-9a-z]/g, "");
563
- return normalized.length > 0 ? normalized.slice(-8) : void 0;
564
- }
565
- function isLikelyApnsToken(value) {
566
- return value.length <= MAX_APNS_TOKEN_HEX_LENGTH && /^[0-9a-f]{32,}$/i.test(value);
567
- }
568
- function parseReason(body) {
569
- const trimmed = body.trim();
570
- if (!trimmed) return;
571
- try {
572
- const parsed = JSON.parse(trimmed);
573
- return typeof parsed.reason === "string" && parsed.reason.trim().length > 0 ? parsed.reason.trim() : trimmed.slice(0, 200);
574
- } catch {
575
- return trimmed.slice(0, 200);
576
- }
577
- }
578
- function toBase64UrlBytes(value) {
579
- return Buffer.from(value).toString("base64").replace(/\+/g, "-").replace(/\//g, "_").replace(/=+$/g, "");
580
- }
581
- function toBase64UrlJson(value) {
582
- return toBase64UrlBytes(Buffer.from(JSON.stringify(value)));
583
- }
584
- function getJwtCacheKey(auth) {
585
- const keyHash = createHash("sha256").update(auth.privateKey).digest("hex");
586
- return `${auth.teamId}:${auth.keyId}:${keyHash}`;
587
- }
588
- function getApnsBearerToken(auth, nowMs = Date.now()) {
589
- const cacheKey = getJwtCacheKey(auth);
590
- if (cachedJwt && cachedJwt.cacheKey === cacheKey && nowMs < cachedJwt.expiresAtMs) return cachedJwt.token;
591
- const iat = Math.floor(nowMs / 1e3);
592
- const signingInput = `${toBase64UrlJson({
593
- alg: "ES256",
594
- kid: auth.keyId,
595
- typ: "JWT"
596
- })}.${toBase64UrlJson({
597
- iss: auth.teamId,
598
- iat
599
- })}`;
600
- const token = `${signingInput}.${toBase64UrlBytes(sign("sha256", Buffer.from(signingInput, "utf8"), {
601
- key: createPrivateKey(auth.privateKey),
602
- dsaEncoding: "ieee-p1363"
603
- }))}`;
604
- cachedJwt = {
605
- cacheKey,
606
- token,
607
- expiresAtMs: nowMs + APNS_JWT_TTL_MS
608
- };
609
- return token;
610
- }
611
- function normalizePrivateKey(value) {
612
- return value.trim().replace(/\\n/g, "\n");
613
- }
614
- function normalizeNonEmptyString(value) {
615
- const trimmed = value?.trim() ?? "";
616
- return trimmed.length > 0 ? trimmed : null;
617
- }
618
- function normalizeDistribution(value) {
619
- if (typeof value !== "string") return null;
620
- return value.trim().toLowerCase() === "official" ? "official" : null;
621
- }
622
- function normalizeDirectRegistration(record) {
623
- if (typeof record.nodeId !== "string" || typeof record.token !== "string") return null;
624
- const nodeId = normalizeNodeId(record.nodeId);
625
- const token = normalizeApnsToken(record.token);
626
- const topic = normalizeTopic(typeof record.topic === "string" ? record.topic : "");
627
- const environment = normalizeApnsEnvironment(record.environment) ?? "sandbox";
628
- const updatedAtMs = typeof record.updatedAtMs === "number" && Number.isFinite(record.updatedAtMs) ? Math.trunc(record.updatedAtMs) : 0;
629
- if (!isValidNodeId(nodeId) || !isValidTopic(topic) || !isLikelyApnsToken(token)) return null;
630
- return {
631
- nodeId,
632
- transport: "direct",
633
- token,
634
- topic,
635
- environment,
636
- updatedAtMs
637
- };
638
- }
639
- function normalizeRelayRegistration(record) {
640
- if (typeof record.nodeId !== "string" || typeof record.relayHandle !== "string" || typeof record.sendGrant !== "string" || typeof record.installationId !== "string") return null;
641
- const nodeId = normalizeNodeId(record.nodeId);
642
- const relayHandle = normalizeRelayHandle(record.relayHandle);
643
- const sendGrant = record.sendGrant.trim();
644
- const installationId = normalizeInstallationId(record.installationId);
645
- const topic = normalizeTopic(typeof record.topic === "string" ? record.topic : "");
646
- const environment = normalizeApnsEnvironment(record.environment);
647
- const distribution = normalizeDistribution(record.distribution);
648
- const updatedAtMs = typeof record.updatedAtMs === "number" && Number.isFinite(record.updatedAtMs) ? Math.trunc(record.updatedAtMs) : 0;
649
- if (!isValidNodeId(nodeId) || !relayHandle || !sendGrant || !installationId || !isValidTopic(topic) || environment !== "production" || distribution !== "official") return null;
650
- return {
651
- nodeId,
652
- transport: "relay",
653
- relayHandle,
654
- sendGrant,
655
- installationId,
656
- topic,
657
- environment,
658
- distribution,
659
- updatedAtMs,
660
- tokenDebugSuffix: normalizeTokenDebugSuffix(record.tokenDebugSuffix)
661
- };
662
- }
663
- function normalizeStoredRegistration(record) {
664
- if (!record || typeof record !== "object" || Array.isArray(record)) return null;
665
- const candidate = record;
666
- if ((typeof candidate.transport === "string" ? candidate.transport.trim().toLowerCase() : "direct") === "relay") return normalizeRelayRegistration(candidate);
667
- return normalizeDirectRegistration(candidate);
668
- }
669
- async function loadRegistrationsState(baseDir) {
670
- const existing = await readJsonFile(resolveApnsRegistrationPath(baseDir));
671
- if (!existing || typeof existing !== "object") return { registrationsByNodeId: {} };
672
- const registrations = existing.registrationsByNodeId && typeof existing.registrationsByNodeId === "object" && !Array.isArray(existing.registrationsByNodeId) ? existing.registrationsByNodeId : {};
673
- const normalized = {};
674
- for (const [nodeId, record] of Object.entries(registrations)) {
675
- const registration = normalizeStoredRegistration(record);
676
- if (registration) {
677
- const normalizedNodeId = normalizeNodeId(nodeId);
678
- normalized[isValidNodeId(normalizedNodeId) ? normalizedNodeId : registration.nodeId] = registration;
679
- }
680
- }
681
- return { registrationsByNodeId: normalized };
682
- }
683
- async function persistRegistrationsState(state, baseDir) {
684
- await writeJsonAtomic(resolveApnsRegistrationPath(baseDir), state, {
685
- mode: 384,
686
- ensureDirMode: 448,
687
- trailingNewline: true
688
- });
689
- }
690
- function normalizeApnsEnvironment(value) {
691
- if (typeof value !== "string") return null;
692
- const normalized = value.trim().toLowerCase();
693
- if (normalized === "sandbox" || normalized === "production") return normalized;
694
- return null;
695
- }
696
- async function registerApnsRegistration(params) {
697
- const nodeId = normalizeNodeId(params.nodeId);
698
- const topic = normalizeTopic(params.topic);
699
- if (!isValidNodeId(nodeId)) throw new Error("nodeId required");
700
- if (!isValidTopic(topic)) throw new Error("topic required");
701
- return await withLock(async () => {
702
- const state = await loadRegistrationsState(params.baseDir);
703
- const updatedAtMs = Date.now();
704
- let next;
705
- if (params.transport === "relay") {
706
- const relayHandle = validateRelayIdentifier(normalizeRelayHandle(params.relayHandle), "relayHandle");
707
- const sendGrant = validateRelayIdentifier(params.sendGrant.trim(), "sendGrant", MAX_SEND_GRANT_LENGTH);
708
- const installationId = validateRelayIdentifier(normalizeInstallationId(params.installationId), "installationId");
709
- const environment = normalizeApnsEnvironment(params.environment);
710
- const distribution = normalizeDistribution(params.distribution);
711
- if (environment !== "production") throw new Error("relay registrations must use production environment");
712
- if (distribution !== "official") throw new Error("relay registrations must use official distribution");
713
- next = {
714
- nodeId,
715
- transport: "relay",
716
- relayHandle,
717
- sendGrant,
718
- installationId,
719
- topic,
720
- environment,
721
- distribution,
722
- updatedAtMs,
723
- tokenDebugSuffix: normalizeTokenDebugSuffix(params.tokenDebugSuffix)
724
- };
725
- } else {
726
- const token = normalizeApnsToken(params.token);
727
- const environment = normalizeApnsEnvironment(params.environment) ?? "sandbox";
728
- if (!isLikelyApnsToken(token)) throw new Error("invalid APNs token");
729
- next = {
730
- nodeId,
731
- transport: "direct",
732
- token,
733
- topic,
734
- environment,
735
- updatedAtMs
736
- };
737
- }
738
- state.registrationsByNodeId[nodeId] = next;
739
- await persistRegistrationsState(state, params.baseDir);
740
- return next;
741
- });
742
- }
743
- async function loadApnsRegistration(nodeId, baseDir) {
744
- const normalizedNodeId = normalizeNodeId(nodeId);
745
- if (!normalizedNodeId) return null;
746
- return (await loadRegistrationsState(baseDir)).registrationsByNodeId[normalizedNodeId] ?? null;
747
- }
748
- function isSameApnsRegistration(a, b) {
749
- if (a.nodeId !== b.nodeId || a.transport !== b.transport || a.topic !== b.topic || a.environment !== b.environment || a.updatedAtMs !== b.updatedAtMs) return false;
750
- if (a.transport === "direct" && b.transport === "direct") return a.token === b.token;
751
- if (a.transport === "relay" && b.transport === "relay") return a.relayHandle === b.relayHandle && a.sendGrant === b.sendGrant && a.installationId === b.installationId && a.distribution === b.distribution && a.tokenDebugSuffix === b.tokenDebugSuffix;
752
- return false;
753
- }
754
- async function clearApnsRegistrationIfCurrent(params) {
755
- const normalizedNodeId = normalizeNodeId(params.nodeId);
756
- if (!normalizedNodeId) return false;
757
- return await withLock(async () => {
758
- const state = await loadRegistrationsState(params.baseDir);
759
- const current = state.registrationsByNodeId[normalizedNodeId];
760
- if (!current || !isSameApnsRegistration(current, params.registration)) return false;
761
- delete state.registrationsByNodeId[normalizedNodeId];
762
- await persistRegistrationsState(state, params.baseDir);
763
- return true;
764
- });
765
- }
766
- function shouldInvalidateApnsRegistration(result) {
767
- if (result.status === 410) return true;
768
- return result.status === 400 && result.reason?.trim() === "BadDeviceToken";
769
- }
770
- function shouldClearStoredApnsRegistration(params) {
771
- if (params.registration.transport !== "direct") return false;
772
- if (params.overrideEnvironment && params.overrideEnvironment !== params.registration.environment) return false;
773
- return shouldInvalidateApnsRegistration(params.result);
774
- }
775
- async function resolveApnsAuthConfigFromEnv(env = process.env) {
776
- const teamId = normalizeNonEmptyString(env.MOLDCLAW_APNS_TEAM_ID);
777
- const keyId = normalizeNonEmptyString(env.MOLDCLAW_APNS_KEY_ID);
778
- if (!teamId || !keyId) return {
779
- ok: false,
780
- error: "APNs auth missing: set MOLDCLAW_APNS_TEAM_ID and MOLDCLAW_APNS_KEY_ID"
781
- };
782
- const inlineKeyRaw = normalizeNonEmptyString(env.MOLDCLAW_APNS_PRIVATE_KEY_P8) ?? normalizeNonEmptyString(env.MOLDCLAW_APNS_PRIVATE_KEY);
783
- if (inlineKeyRaw) return {
784
- ok: true,
785
- value: {
786
- teamId,
787
- keyId,
788
- privateKey: normalizePrivateKey(inlineKeyRaw)
789
- }
790
- };
791
- const keyPath = normalizeNonEmptyString(env.MOLDCLAW_APNS_PRIVATE_KEY_PATH);
792
- if (!keyPath) return {
793
- ok: false,
794
- error: "APNs private key missing: set MOLDCLAW_APNS_PRIVATE_KEY_P8 or MOLDCLAW_APNS_PRIVATE_KEY_PATH"
795
- };
796
- try {
797
- return {
798
- ok: true,
799
- value: {
800
- teamId,
801
- keyId,
802
- privateKey: normalizePrivateKey(await fs.readFile(keyPath, "utf8"))
803
- }
804
- };
805
- } catch (err) {
806
- return {
807
- ok: false,
808
- error: `failed reading MOLDCLAW_APNS_PRIVATE_KEY_PATH (${keyPath}): ${err instanceof Error ? err.message : String(err)}`
809
- };
810
- }
811
- }
812
- async function sendApnsRequest(params) {
813
- const authority = params.environment === "production" ? "https://api.push.apple.com" : "https://api.sandbox.push.apple.com";
814
- const body = JSON.stringify(params.payload);
815
- const requestPath = `/3/device/${params.token}`;
816
- return await new Promise((resolve, reject) => {
817
- const client = http2.connect(authority);
818
- let settled = false;
819
- const fail = (err) => {
820
- if (settled) return;
821
- settled = true;
822
- client.destroy();
823
- reject(err);
824
- };
825
- const finish = (result) => {
826
- if (settled) return;
827
- settled = true;
828
- client.close();
829
- resolve(result);
830
- };
831
- client.once("error", (err) => fail(err));
832
- const req = client.request({
833
- ":method": "POST",
834
- ":path": requestPath,
835
- authorization: `bearer ${params.bearerToken}`,
836
- "apns-topic": params.topic,
837
- "apns-push-type": params.pushType,
838
- "apns-priority": params.priority,
839
- "apns-expiration": "0",
840
- "content-type": "application/json",
841
- "content-length": Buffer.byteLength(body).toString()
842
- });
843
- let statusCode = 0;
844
- let apnsId;
845
- let responseBody = "";
846
- req.setEncoding("utf8");
847
- req.setTimeout(params.timeoutMs, () => {
848
- req.close(http2.constants.NGHTTP2_CANCEL);
849
- fail(/* @__PURE__ */ new Error(`APNs request timed out after ${params.timeoutMs}ms`));
850
- });
851
- req.on("response", (headers) => {
852
- const statusHeader = headers[":status"];
853
- statusCode = typeof statusHeader === "number" ? statusHeader : Number(statusHeader ?? 0);
854
- const idHeader = headers["apns-id"];
855
- if (typeof idHeader === "string" && idHeader.trim().length > 0) apnsId = idHeader.trim();
856
- });
857
- req.on("data", (chunk) => {
858
- if (typeof chunk === "string") responseBody += chunk;
859
- });
860
- req.on("end", () => {
861
- finish({
862
- status: statusCode,
863
- apnsId,
864
- body: responseBody
865
- });
866
- });
867
- req.on("error", (err) => fail(err));
868
- req.end(body);
869
- });
870
- }
871
- function resolveApnsTimeoutMs(timeoutMs) {
872
- return typeof timeoutMs === "number" && Number.isFinite(timeoutMs) ? Math.max(1e3, Math.trunc(timeoutMs)) : DEFAULT_APNS_TIMEOUT_MS;
873
- }
874
- function resolveDirectSendContext(params) {
875
- const token = normalizeApnsToken(params.registration.token);
876
- if (!isLikelyApnsToken(token)) throw new Error("invalid APNs token");
877
- const topic = normalizeTopic(params.registration.topic);
878
- if (!isValidTopic(topic)) throw new Error("topic required");
879
- return {
880
- token,
881
- topic,
882
- environment: params.registration.environment,
883
- bearerToken: getApnsBearerToken(params.auth)
884
- };
885
- }
886
- function toPushMetadata(params) {
887
- return {
888
- kind: params.kind,
889
- nodeId: params.nodeId,
890
- ts: Date.now(),
891
- ...params.reason ? { reason: params.reason } : {}
892
- };
893
- }
894
- function resolveRegistrationDebugSuffix(registration, relayResult) {
895
- if (registration.transport === "direct") return registration.token.slice(-8);
896
- return relayResult?.tokenSuffix ?? registration.tokenDebugSuffix ?? registration.relayHandle.slice(-8);
897
- }
898
- function toPushResult(params) {
899
- const response = "body" in params.response ? {
900
- ok: params.response.status === 200,
901
- status: params.response.status,
902
- apnsId: params.response.apnsId,
903
- reason: parseReason(params.response.body),
904
- environment: params.registration.environment,
905
- tokenSuffix: params.tokenSuffix
906
- } : params.response;
907
- return {
908
- ok: response.ok,
909
- status: response.status,
910
- apnsId: response.apnsId,
911
- reason: response.reason,
912
- tokenSuffix: params.tokenSuffix ?? resolveRegistrationDebugSuffix(params.registration, "tokenSuffix" in response ? response : void 0),
913
- topic: params.registration.topic,
914
- environment: params.registration.transport === "relay" ? "production" : response.environment,
915
- transport: params.registration.transport
916
- };
917
- }
918
- async function sendDirectApnsPush(params) {
919
- const { token, topic, environment, bearerToken } = resolveDirectSendContext({
920
- auth: params.auth,
921
- registration: params.registration
922
- });
923
- const response = await (params.requestSender ?? sendApnsRequest)({
924
- token,
925
- topic,
926
- environment,
927
- bearerToken,
928
- payload: params.payload,
929
- timeoutMs: resolveApnsTimeoutMs(params.timeoutMs),
930
- pushType: params.pushType,
931
- priority: params.priority
932
- });
933
- return toPushResult({
934
- registration: params.registration,
935
- response,
936
- tokenSuffix: token.slice(-8)
937
- });
938
- }
939
- async function sendRelayApnsPush(params) {
940
- const response = await sendApnsRelayPush({
941
- relayConfig: params.relayConfig,
942
- sendGrant: params.registration.sendGrant,
943
- relayHandle: params.registration.relayHandle,
944
- payload: params.payload,
945
- pushType: params.pushType,
946
- priority: params.priority,
947
- gatewayIdentity: params.gatewayIdentity,
948
- requestSender: params.requestSender
949
- });
950
- return toPushResult({
951
- registration: params.registration,
952
- response
953
- });
954
- }
955
- function createAlertPayload(params) {
956
- return {
957
- aps: {
958
- alert: {
959
- title: params.title,
960
- body: params.body
961
- },
962
- sound: "default"
963
- },
964
- moldclaw: toPushMetadata({
965
- kind: "push.test",
966
- nodeId: params.nodeId
967
- })
968
- };
969
- }
970
- function createBackgroundPayload(params) {
971
- return {
972
- aps: { "content-available": 1 },
973
- moldclaw: toPushMetadata({
974
- kind: "node.wake",
975
- reason: params.wakeReason ?? "node.invoke",
976
- nodeId: params.nodeId
977
- })
978
- };
979
- }
980
- async function sendApnsAlert(params) {
981
- const payload = createAlertPayload({
982
- nodeId: params.nodeId,
983
- title: params.title,
984
- body: params.body
985
- });
986
- if (params.registration.transport === "relay") {
987
- const relayParams = params;
988
- return await sendRelayApnsPush({
989
- relayConfig: relayParams.relayConfig,
990
- registration: relayParams.registration,
991
- payload,
992
- pushType: "alert",
993
- priority: "10",
994
- gatewayIdentity: relayParams.relayGatewayIdentity,
995
- requestSender: relayParams.relayRequestSender
996
- });
997
- }
998
- const directParams = params;
999
- return await sendDirectApnsPush({
1000
- auth: directParams.auth,
1001
- registration: directParams.registration,
1002
- payload,
1003
- timeoutMs: directParams.timeoutMs,
1004
- requestSender: directParams.requestSender,
1005
- pushType: "alert",
1006
- priority: "10"
1007
- });
1008
- }
1009
- async function sendApnsBackgroundWake(params) {
1010
- const payload = createBackgroundPayload({
1011
- nodeId: params.nodeId,
1012
- wakeReason: params.wakeReason
1013
- });
1014
- if (params.registration.transport === "relay") {
1015
- const relayParams = params;
1016
- return await sendRelayApnsPush({
1017
- relayConfig: relayParams.relayConfig,
1018
- registration: relayParams.registration,
1019
- payload,
1020
- pushType: "background",
1021
- priority: "5",
1022
- gatewayIdentity: relayParams.relayGatewayIdentity,
1023
- requestSender: relayParams.relayRequestSender
1024
- });
1025
- }
1026
- const directParams = params;
1027
- return await sendDirectApnsPush({
1028
- auth: directParams.auth,
1029
- registration: directParams.registration,
1030
- payload,
1031
- timeoutMs: directParams.timeoutMs,
1032
- requestSender: directParams.requestSender,
1033
- pushType: "background",
1034
- priority: "5"
1035
- });
1036
- }
1037
- //#endregion
1038
- export { resolveApnsAuthConfigFromEnv as a, shouldClearStoredApnsRegistration as c, parseMessageWithAttachments as d, formatForLog as f, setGatewayWsLogStyle as g, summarizeAgentEventForWsLog as h, registerApnsRegistration as i, resolveApnsRelayConfigFromEnv as l, shouldLogWs as m, loadApnsRegistration as n, sendApnsAlert as o, logWs as p, normalizeApnsEnvironment as r, sendApnsBackgroundWake as s, clearApnsRegistrationIfCurrent as t, normalizeRpcAttachmentsToChatAttachments as u };