@makaio/framework 1.0.0-dev-1781022866275 → 1.0.0-dev-1781023871421

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 (456) hide show
  1. package/dist/.makaio-build.json +5 -0
  2. package/dist/account-identity-DT5NOtFi.mjs +1 -0
  3. package/dist/adapter-C1eI-fGV.mjs +1 -0
  4. package/dist/adapters/acp-client/index.d.mts +6208 -0
  5. package/dist/adapters/acp-client/index.mjs +3 -0
  6. package/dist/adapters/config/index.d.mts +429 -0
  7. package/dist/adapters/config/index.mjs +1 -0
  8. package/dist/adapters/index.d.mts +4202 -0
  9. package/dist/adapters/index.mjs +18 -0
  10. package/dist/adapters/node.d.mts +263 -0
  11. package/dist/adapters/node.mjs +4 -0
  12. package/dist/adapters/stream-session/index.d.mts +1414 -0
  13. package/dist/adapters/stream-session/index.mjs +1 -0
  14. package/dist/adapters/stream-session/testing/index.d.mts +29 -0
  15. package/dist/adapters/stream-session/testing/index.mjs +1 -0
  16. package/dist/artifact-B3npq1cy.mjs +1 -0
  17. package/dist/base-orchestrator-wyumsn3b.d.mts +772 -0
  18. package/dist/bus/index.d.mts +3994 -0
  19. package/dist/bus/index.mjs +1 -0
  20. package/dist/bus-Caz3Jpbc.mjs +1 -0
  21. package/dist/bus-Hb-LGzgb.mjs +2 -0
  22. package/dist/capability-service-CJbmhfv9.mjs +1 -0
  23. package/dist/chunk-DTipWd-i.mjs +1 -0
  24. package/dist/chunk-cpUYaJdV.mjs +1 -0
  25. package/dist/cleanEnvForAdapter-KkYzQa1f.mjs +1 -0
  26. package/dist/client-bx74gm4R.mjs +1 -0
  27. package/dist/clients/index.d.mts +2639 -0
  28. package/dist/clients/index.mjs +2 -0
  29. package/dist/clients-namespace-GmSJpBUV.d.mts +332 -0
  30. package/dist/config-namespace-CPY9YsR8.d.mts +638 -0
  31. package/dist/config-namespace-ncYg2ct_.mjs +1 -0
  32. package/dist/contracts/adapter/index.d.mts +3 -0
  33. package/dist/contracts/adapter/index.mjs +1 -0
  34. package/dist/contracts/adapter/schemas/session-lineage.d.mts +2 -0
  35. package/dist/contracts/adapter/schemas/session-lineage.mjs +1 -0
  36. package/dist/contracts/artifact/index.d.mts +2 -0
  37. package/dist/contracts/artifact/index.mjs +1 -0
  38. package/dist/contracts/client/index.d.mts +3 -0
  39. package/dist/contracts/client/index.mjs +1 -0
  40. package/dist/contracts/common/index.d.mts +2 -0
  41. package/dist/contracts/common/index.mjs +1 -0
  42. package/dist/contracts/config/index.d.mts +455 -0
  43. package/dist/contracts/config/index.mjs +1 -0
  44. package/dist/contracts/extension/index.d.mts +4 -0
  45. package/dist/contracts/extension/index.mjs +1 -0
  46. package/dist/contracts/facet/index.d.mts +2 -0
  47. package/dist/contracts/facet/index.mjs +1 -0
  48. package/dist/contracts/harness/index.d.mts +2 -0
  49. package/dist/contracts/harness/index.mjs +1 -0
  50. package/dist/contracts/host/index.d.mts +2 -0
  51. package/dist/contracts/host/index.mjs +1 -0
  52. package/dist/contracts/index.d.mts +23046 -0
  53. package/dist/contracts/index.mjs +1 -0
  54. package/dist/contracts/materialization/index.d.mts +4 -0
  55. package/dist/contracts/materialization/index.mjs +1 -0
  56. package/dist/contracts/model-registry/index.d.mts +2 -0
  57. package/dist/contracts/model-registry/index.mjs +1 -0
  58. package/dist/contracts/native-session-supervisor/index.d.mts +2 -0
  59. package/dist/contracts/native-session-supervisor/index.mjs +1 -0
  60. package/dist/contracts/platform/index.d.mts +2 -0
  61. package/dist/contracts/platform/index.mjs +1 -0
  62. package/dist/contracts/provider/index.d.mts +3 -0
  63. package/dist/contracts/provider/index.mjs +1 -0
  64. package/dist/contracts/session/index.d.mts +3 -0
  65. package/dist/contracts/session/index.mjs +1 -0
  66. package/dist/contracts/shared/index.d.mts +2 -0
  67. package/dist/contracts/shared/index.mjs +1 -0
  68. package/dist/contracts/skill/index.d.mts +2 -0
  69. package/dist/contracts/skill/index.mjs +1 -0
  70. package/dist/contracts/telemetry/index.d.mts +2 -0
  71. package/dist/contracts/telemetry/index.mjs +1 -0
  72. package/dist/contracts/timeout/index.d.mts +2 -0
  73. package/dist/contracts/timeout/index.mjs +1 -0
  74. package/dist/contracts/toast/index.d.mts +198 -0
  75. package/dist/contracts/toast/index.mjs +1 -0
  76. package/dist/contracts/variant/index.d.mts +2 -0
  77. package/dist/contracts/variant/index.mjs +1 -0
  78. package/dist/core/index.d.mts +1263 -0
  79. package/dist/core/index.mjs +1 -0
  80. package/dist/credential-ref-YWQQENEo.mjs +1 -0
  81. package/dist/cursor-storage-CtVJ3JzB.mjs +1 -0
  82. package/dist/definition-BLCdXGzh.d.mts +383 -0
  83. package/dist/definition-CrgHIpTK.d.mts +60 -0
  84. package/dist/definition-DZMXOnjX.mjs +1 -0
  85. package/dist/definition-pkJ6szUl.d.mts +158 -0
  86. package/dist/drizzle-Eq8W1EbD.mjs +1 -0
  87. package/dist/event-Ca2yUf5i.mjs +1 -0
  88. package/dist/execution-target-CRPTfZlc.mjs +1 -0
  89. package/dist/extension-C-4BHMRI.mjs +1 -0
  90. package/dist/extension-CpIUgBKI.mjs +1 -0
  91. package/dist/extension-namespace-cMh_mMiL.mjs +1 -0
  92. package/dist/facet-BuwhrThl.mjs +1 -0
  93. package/dist/filesystem-service-B8rhBRgB.mjs +1 -0
  94. package/dist/filesystem-service-p_iJVHd4.d.mts +66 -0
  95. package/dist/git/index.d.mts +210 -0
  96. package/dist/git/index.mjs +18 -0
  97. package/dist/globby-rtWVaFHv.mjs +41 -0
  98. package/dist/handlers-CkTsQLra.mjs +41 -0
  99. package/dist/harness-BRCMcvQN.mjs +1 -0
  100. package/dist/hooks/index.d.mts +423 -0
  101. package/dist/hooks/index.mjs +1 -0
  102. package/dist/host-Br9VuOyr.mjs +1 -0
  103. package/dist/identity-Cz2IeEtm.mjs +1 -0
  104. package/dist/index-472sOmsW.d.mts +218 -0
  105. package/dist/index-8SZkg7s6.d.mts +353 -0
  106. package/dist/index-B3PK4FIn.d.mts +5116 -0
  107. package/dist/index-B80L4YqA.d.mts +180 -0
  108. package/dist/index-BFg9BUpx.d.mts +355 -0
  109. package/dist/index-BGfWS6GE.d.mts +483 -0
  110. package/dist/index-BVgfS-AJ.d.mts +109 -0
  111. package/dist/index-B_zQC98V.d.mts +995 -0
  112. package/dist/index-Bh_Ne7LF.d.mts +1008 -0
  113. package/dist/index-Bvb2mMH6.d.mts +1730 -0
  114. package/dist/index-CCGVh9BF2.d.mts +749 -0
  115. package/dist/index-CGmcS0Ma.d.mts +412 -0
  116. package/dist/index-CHQ1SqT0.d.mts +117 -0
  117. package/dist/index-CLpjm52M.d.mts +183 -0
  118. package/dist/index-Caig6TeF.d.mts +6746 -0
  119. package/dist/index-CelJCBjk.d.mts +2992 -0
  120. package/dist/index-ChunCFu4.d.mts +11 -0
  121. package/dist/index-Cm0dUkWL.d.mts +4651 -0
  122. package/dist/index-CokQYGVP.d.mts +184 -0
  123. package/dist/index-Cs0kZXIz2.d.mts +37 -0
  124. package/dist/index-D5d5HeWI2.d.mts +259 -0
  125. package/dist/index-D90OmGmV.d.mts +389 -0
  126. package/dist/index-D9MwJ2Q8.d.mts +67 -0
  127. package/dist/index-DANINzMu.d.mts +40 -0
  128. package/dist/index-DBw-89vC2.d.mts +3640 -0
  129. package/dist/index-DGBu6bHi2.d.mts +438 -0
  130. package/dist/index-DKC62dY5.d.mts +146 -0
  131. package/dist/index-DKia0MX1.d.mts +43 -0
  132. package/dist/index-DMKnON5s.d.mts +28 -0
  133. package/dist/index-DUaw0Dw8.d.mts +14747 -0
  134. package/dist/index-De3kPhlN.d.mts +72 -0
  135. package/dist/index-L4GjJDKb.d.mts +822 -0
  136. package/dist/index-U-A8eyGT.d.mts +1490 -0
  137. package/dist/index-eemAKwsB.d.mts +362 -0
  138. package/dist/index-mNec7V-9.d.mts +1075 -0
  139. package/dist/index-soFznFCy2.d.mts +89 -0
  140. package/dist/index-vtXJuwrz.d.mts +40 -0
  141. package/dist/index-x_lVDp_J.d.mts +134 -0
  142. package/dist/json-value-CmhSGMLv.mjs +1 -0
  143. package/dist/kernel/cli/index.d.mts +143 -0
  144. package/dist/kernel/cli/index.mjs +1 -0
  145. package/dist/kernel/cli/schemas.d.mts +64 -0
  146. package/dist/kernel/cli/schemas.mjs +1 -0
  147. package/dist/kernel/extension/index.d.mts +2 -0
  148. package/dist/kernel/extension/index.mjs +1 -0
  149. package/dist/kernel/index.d.mts +296 -0
  150. package/dist/kernel/index.mjs +1 -0
  151. package/dist/kernel/namespace/index.d.mts +2 -0
  152. package/dist/kernel/namespace/index.mjs +1 -0
  153. package/dist/kernel/observability/index.d.mts +2 -0
  154. package/dist/kernel/observability/index.mjs +1 -0
  155. package/dist/kernel/providers/index.d.mts +2 -0
  156. package/dist/kernel/providers/index.mjs +1 -0
  157. package/dist/kernel/window/index.d.mts +2 -0
  158. package/dist/kernel/window/index.mjs +1 -0
  159. package/dist/materialization-CuUBu4XI.mjs +1 -0
  160. package/dist/model-registry-CfXytvzx.mjs +1 -0
  161. package/dist/model-registry-Scn_MC2d.mjs +1 -0
  162. package/dist/namespace-5QQqbF-B.d.mts +3133 -0
  163. package/dist/namespace-BM7Djng9.d.mts +189 -0
  164. package/dist/namespace-BoD94mrN.mjs +1 -0
  165. package/dist/namespace-BwzZJqTV.mjs +1 -0
  166. package/dist/namespace-CFLAmQfh.mjs +1 -0
  167. package/dist/namespace-CTm3nEvh.d.mts +51 -0
  168. package/dist/namespace-CaaNnKcR.d.mts +921 -0
  169. package/dist/namespace-CaoZ3S78.d.mts +43 -0
  170. package/dist/namespace-CxhsoFUP.d.mts +607 -0
  171. package/dist/namespace-DD8Oiqo7.d.mts +580 -0
  172. package/dist/namespace-DLovh2Ws.d.mts +1313 -0
  173. package/dist/namespace-DgqkaOVu.d.mts +768 -0
  174. package/dist/namespace-DkRgbZYn.mjs +1 -0
  175. package/dist/namespace-Dr8K0MCp.d.mts +2047 -0
  176. package/dist/namespace-DuXK5AYN.mjs +1 -0
  177. package/dist/namespace-EQniz-Aw.d.mts +142 -0
  178. package/dist/namespace-IV1QK__V.d.mts +159 -0
  179. package/dist/namespace-LViZ-EQk.mjs +1 -0
  180. package/dist/namespace-TyiTsLFv.d.mts +3020 -0
  181. package/dist/namespace-Yna5-Pws.mjs +1 -0
  182. package/dist/namespace-xcmbQlxh.mjs +1 -0
  183. package/dist/native-session-supervisor-B1TnaPUF.mjs +1 -0
  184. package/dist/node/bus-server/index.d.mts +178 -0
  185. package/dist/node/bus-server/index.mjs +1 -0
  186. package/dist/node/bus-server/server-lifecycle.d.mts +2 -0
  187. package/dist/node/bus-server/server-lifecycle.mjs +1 -0
  188. package/dist/node/machine-identity/index.d.mts +85 -0
  189. package/dist/node/machine-identity/index.mjs +3 -0
  190. package/dist/node/transports/index.d.mts +1945 -0
  191. package/dist/node/transports/index.mjs +2 -0
  192. package/dist/orchestrator-shared-CIDiFJMD.mjs +1 -0
  193. package/dist/orchestrator-shared-Dfa7FMyw.d.mts +249 -0
  194. package/dist/package-DKVlsMP3.mjs +1 -0
  195. package/dist/platform-DZ7z-wXD.mjs +1 -0
  196. package/dist/profile-6ynCD5k3.mjs +1 -0
  197. package/dist/provider-context-CK6B4X_8.mjs +1 -0
  198. package/dist/providers/index.d.mts +135 -0
  199. package/dist/providers/index.mjs +1 -0
  200. package/dist/providers-namespace-DSEpli4A.d.mts +583 -0
  201. package/dist/providers-u8i15co9.mjs +1 -0
  202. package/dist/schema-CoyE6mPt.mjs +1 -0
  203. package/dist/schema-M5YTvSAG.d.mts +949 -0
  204. package/dist/schema-e0wU_lcV.mjs +1 -0
  205. package/dist/schema-introspection-Dn1jWQs1.mjs +1 -0
  206. package/dist/schemas-Bd0OjRQf.d.mts +46 -0
  207. package/dist/schemas-C46QfKzv.d.mts +459 -0
  208. package/dist/schemas-CDBSjg7o.d.mts +237 -0
  209. package/dist/schemas-CR1Rripy.mjs +1 -0
  210. package/dist/schemas-CVvwIfG4.mjs +1 -0
  211. package/dist/schemas-CaLhkkLn.mjs +1 -0
  212. package/dist/schemas-ClOOT1W6.d.mts +174 -0
  213. package/dist/schemas-DATniTHb.d.mts +182 -0
  214. package/dist/schemas-DE-GNmSD.mjs +1 -0
  215. package/dist/schemas-DVF1A4DF.d.mts +160 -0
  216. package/dist/schemas-DaRSfYLf.d.mts +73 -0
  217. package/dist/schemas-DiYVzG6e.d.mts +315 -0
  218. package/dist/schemas-hSrzflwZ.mjs +1 -0
  219. package/dist/schemas-j7ivZ2HI.d.mts +944 -0
  220. package/dist/schemas-jFe1AuI-.mjs +1 -0
  221. package/dist/schemas-wg_6PAdV.d.mts +153 -0
  222. package/dist/scoped-bus-04pwo1uM.mjs +1 -0
  223. package/dist/server-lifecycle-FXTPW39-.mjs +1 -0
  224. package/dist/server-lifecycle-YoSGFGnU.d.mts +160 -0
  225. package/dist/service-base/index.d.mts +98 -0
  226. package/dist/service-base/index.mjs +1 -0
  227. package/dist/services/adapter-runtime/index.d.mts +4 -0
  228. package/dist/services/adapter-runtime/index.mjs +1 -0
  229. package/dist/services/adapter-runtime/namespace.d.mts +2 -0
  230. package/dist/services/adapter-runtime/namespace.mjs +1 -0
  231. package/dist/services/adapter-runtime/schemas.d.mts +2 -0
  232. package/dist/services/adapter-runtime/schemas.mjs +1 -0
  233. package/dist/services/adapter-subsystem/index.d.mts +3 -0
  234. package/dist/services/adapter-subsystem/index.mjs +1 -0
  235. package/dist/services/adapter-subsystem/namespace.d.mts +2 -0
  236. package/dist/services/adapter-subsystem/namespace.mjs +1 -0
  237. package/dist/services/agent-runtime/index.d.mts +3 -0
  238. package/dist/services/agent-runtime/index.mjs +1 -0
  239. package/dist/services/agent-runtime/namespace.d.mts +2 -0
  240. package/dist/services/agent-runtime/namespace.mjs +1 -0
  241. package/dist/services/agent-runtime/schemas.d.mts +2 -0
  242. package/dist/services/agent-runtime/schemas.mjs +1 -0
  243. package/dist/services/capability/index.d.mts +2 -0
  244. package/dist/services/capability/index.mjs +1 -0
  245. package/dist/services/cli-detection/namespace.d.mts +56 -0
  246. package/dist/services/cli-detection/namespace.mjs +1 -0
  247. package/dist/services/codebase/index.d.mts +3 -0
  248. package/dist/services/codebase/index.mjs +1 -0
  249. package/dist/services/codebase/namespace.d.mts +2 -0
  250. package/dist/services/codebase/namespace.mjs +1 -0
  251. package/dist/services/codebase/schemas.d.mts +2 -0
  252. package/dist/services/codebase/schemas.mjs +1 -0
  253. package/dist/services/compression/index.d.mts +3 -0
  254. package/dist/services/compression/index.mjs +1 -0
  255. package/dist/services/compression/namespace.d.mts +2 -0
  256. package/dist/services/compression/namespace.mjs +1 -0
  257. package/dist/services/compression/schemas.d.mts +2 -0
  258. package/dist/services/compression/schemas.mjs +1 -0
  259. package/dist/services/context-rules/index.d.mts +412 -0
  260. package/dist/services/context-rules/index.mjs +1 -0
  261. package/dist/services/credential-change/index.d.mts +17 -0
  262. package/dist/services/credential-change/index.mjs +1 -0
  263. package/dist/services/definition/index.d.mts +2 -0
  264. package/dist/services/definition/index.mjs +1 -0
  265. package/dist/services/definition/namespace.d.mts +71 -0
  266. package/dist/services/definition/namespace.mjs +1 -0
  267. package/dist/services/definition/schemas.d.mts +38 -0
  268. package/dist/services/definition/schemas.mjs +1 -0
  269. package/dist/services/dialog/namespace.d.mts +105 -0
  270. package/dist/services/dialog/namespace.mjs +1 -0
  271. package/dist/services/dialog/schemas.d.mts +109 -0
  272. package/dist/services/dialog/schemas.mjs +1 -0
  273. package/dist/services/execution-target/index.d.mts +4 -0
  274. package/dist/services/execution-target/index.mjs +1 -0
  275. package/dist/services/execution-target/namespace.d.mts +2 -0
  276. package/dist/services/execution-target/namespace.mjs +1 -0
  277. package/dist/services/execution-target/schemas.d.mts +2 -0
  278. package/dist/services/execution-target/schemas.mjs +1 -0
  279. package/dist/services/filesystem/index.d.mts +3 -0
  280. package/dist/services/filesystem/index.mjs +1 -0
  281. package/dist/services/filesystem/namespace.d.mts +432 -0
  282. package/dist/services/filesystem/namespace.mjs +1 -0
  283. package/dist/services/filesystem/schemas.d.mts +240 -0
  284. package/dist/services/filesystem/schemas.mjs +1 -0
  285. package/dist/services/git/namespace.d.mts +1163 -0
  286. package/dist/services/git/namespace.mjs +1 -0
  287. package/dist/services/git/schemas.d.mts +932 -0
  288. package/dist/services/git/schemas.mjs +1 -0
  289. package/dist/services/harness/index.d.mts +861 -0
  290. package/dist/services/harness/index.mjs +1 -0
  291. package/dist/services/harness/storage/schema.d.mts +424 -0
  292. package/dist/services/harness/storage/schema.mjs +1 -0
  293. package/dist/services/index.d.mts +6185 -0
  294. package/dist/services/index.mjs +1 -0
  295. package/dist/services/local-notification/index.d.mts +25 -0
  296. package/dist/services/local-notification/index.mjs +1 -0
  297. package/dist/services/local-notification/namespace.d.mts +73 -0
  298. package/dist/services/local-notification/namespace.mjs +1 -0
  299. package/dist/services/local-notification/schemas.d.mts +88 -0
  300. package/dist/services/local-notification/schemas.mjs +1 -0
  301. package/dist/services/log-import/browser.d.mts +3 -0
  302. package/dist/services/log-import/browser.mjs +1 -0
  303. package/dist/services/log-import/index.d.mts +274 -0
  304. package/dist/services/log-import/index.mjs +2 -0
  305. package/dist/services/log-import/log-import.d.mts +3 -0
  306. package/dist/services/log-import/log-import.mjs +1 -0
  307. package/dist/services/log-import/namespace.d.mts +327 -0
  308. package/dist/services/log-import/namespace.mjs +1 -0
  309. package/dist/services/log-import/schemas.d.mts +217 -0
  310. package/dist/services/log-import/schemas.mjs +1 -0
  311. package/dist/services/model-registry/index.d.mts +2 -0
  312. package/dist/services/model-registry/index.mjs +1 -0
  313. package/dist/services/preferences/index.d.mts +3 -0
  314. package/dist/services/preferences/index.mjs +1 -0
  315. package/dist/services/preferences/schemas.d.mts +2 -0
  316. package/dist/services/preferences/schemas.mjs +1 -0
  317. package/dist/services/preferences/storage-namespace.d.mts +3 -0
  318. package/dist/services/preferences/storage-namespace.mjs +1 -0
  319. package/dist/services/provider-context/index.d.mts +2 -0
  320. package/dist/services/provider-context/index.mjs +1 -0
  321. package/dist/services/provider-runtime/index.d.mts +136 -0
  322. package/dist/services/provider-runtime/index.mjs +1 -0
  323. package/dist/services/session/handlers/index.d.mts +2 -0
  324. package/dist/services/session/handlers/index.mjs +1 -0
  325. package/dist/services/session/index.d.mts +10 -0
  326. package/dist/services/session/index.mjs +1 -0
  327. package/dist/services/session/messages/namespace.d.mts +2 -0
  328. package/dist/services/session/messages/namespace.mjs +1 -0
  329. package/dist/services/session/orchestrator-testing/index.d.mts +2 -0
  330. package/dist/services/session/orchestrator-testing/index.mjs +1 -0
  331. package/dist/services/session/session-events/namespace.d.mts +2 -0
  332. package/dist/services/session/session-events/namespace.mjs +1 -0
  333. package/dist/services/session/storage/namespace.d.mts +2 -0
  334. package/dist/services/session/storage/namespace.mjs +1 -0
  335. package/dist/services/session/storage/schema.d.mts +2 -0
  336. package/dist/services/session/storage/schema.mjs +1 -0
  337. package/dist/services/session/testing/index.d.mts +35 -0
  338. package/dist/services/session/testing/index.mjs +65 -0
  339. package/dist/services/session/testing/orchestrator-shared.d.mts +2 -0
  340. package/dist/services/session/testing/orchestrator-shared.mjs +1 -0
  341. package/dist/services/session/turns/namespace.d.mts +2 -0
  342. package/dist/services/session/turns/namespace.mjs +1 -0
  343. package/dist/services/session-editor/index.d.mts +119 -0
  344. package/dist/services/session-editor/index.mjs +1 -0
  345. package/dist/services/settings/index.d.mts +47 -0
  346. package/dist/services/settings/index.mjs +1 -0
  347. package/dist/services/settings/namespace.d.mts +663 -0
  348. package/dist/services/settings/namespace.mjs +1 -0
  349. package/dist/services/settings/storage/clients-namespace.d.mts +2 -0
  350. package/dist/services/settings/storage/clients-namespace.mjs +1 -0
  351. package/dist/services/settings/storage/extension-configs/namespace.d.mts +184 -0
  352. package/dist/services/settings/storage/extension-configs/namespace.mjs +1 -0
  353. package/dist/services/settings/storage/index.d.mts +4 -0
  354. package/dist/services/settings/storage/index.mjs +1 -0
  355. package/dist/services/settings/storage/providers-namespace.d.mts +2 -0
  356. package/dist/services/settings/storage/providers-namespace.mjs +1 -0
  357. package/dist/services/subagent/index.d.mts +2 -0
  358. package/dist/services/subagent/index.mjs +1 -0
  359. package/dist/services/subagent-template/index.d.mts +3 -0
  360. package/dist/services/subagent-template/index.mjs +1 -0
  361. package/dist/services/subagent-template/namespace.d.mts +2 -0
  362. package/dist/services/subagent-template/namespace.mjs +1 -0
  363. package/dist/services/subagent-template/schemas.d.mts +2 -0
  364. package/dist/services/subagent-template/schemas.mjs +1 -0
  365. package/dist/services/tool-approval/index.d.mts +2 -0
  366. package/dist/services/tool-approval/index.mjs +1 -0
  367. package/dist/services/tools/index.d.mts +2 -0
  368. package/dist/services/tools/index.mjs +1 -0
  369. package/dist/services/tray-menu/index.d.mts +4 -0
  370. package/dist/services/tray-menu/index.mjs +1 -0
  371. package/dist/services/tray-menu/namespace.d.mts +2 -0
  372. package/dist/services/tray-menu/namespace.mjs +1 -0
  373. package/dist/services/tray-menu/schemas.d.mts +2 -0
  374. package/dist/services/tray-menu/schemas.mjs +1 -0
  375. package/dist/services/turn/index.d.mts +2 -0
  376. package/dist/services/turn/index.mjs +1 -0
  377. package/dist/services/turn/namespace.d.mts +2 -0
  378. package/dist/services/turn/namespace.mjs +1 -0
  379. package/dist/services/turn/schemas.d.mts +335 -0
  380. package/dist/services/turn/schemas.mjs +1 -0
  381. package/dist/session-BoldSdNZ2.mjs +134 -0
  382. package/dist/session-DuVOYctZ.mjs +1 -0
  383. package/dist/session-lineage-CRsc9g1x.d.mts +65 -0
  384. package/dist/shared-DpOEfD8F.mjs +1 -0
  385. package/dist/shared-schemas-CPShiLNp.mjs +1 -0
  386. package/dist/skill-CQO4mDqK.mjs +1 -0
  387. package/dist/storage/drizzle/client.d.mts +78 -0
  388. package/dist/storage/drizzle/client.mjs +1 -0
  389. package/dist/storage/drizzle/index.d.mts +137 -0
  390. package/dist/storage/drizzle/index.mjs +1 -0
  391. package/dist/storage/handlers/drizzle/index.d.mts +2 -0
  392. package/dist/storage/handlers/drizzle/index.mjs +1 -0
  393. package/dist/storage/handlers/index.d.mts +33 -0
  394. package/dist/storage/handlers/index.mjs +1 -0
  395. package/dist/storage/index.d.mts +192 -0
  396. package/dist/storage/index.mjs +1 -0
  397. package/dist/storage-namespace-BXkoh5Sy.d.mts +221 -0
  398. package/dist/storage-namespace-DWsYLAXa.mjs +1 -0
  399. package/dist/storage-namespace-definition-Bkx5rSto.d.mts +17 -0
  400. package/dist/storage-namespace-definition-CqSdsuCC.mjs +1 -0
  401. package/dist/style.css +3782 -0
  402. package/dist/telemetry-CvdLBWuk.mjs +1 -0
  403. package/dist/testing/drizzle-harness.d.mts +130 -0
  404. package/dist/testing/drizzle-harness.mjs +1 -0
  405. package/dist/testing/index.d.mts +106 -0
  406. package/dist/testing/index.mjs +1 -0
  407. package/dist/timeout-XsYIOKrc.mjs +1 -0
  408. package/dist/tool-approval-service-BvZWhYZp.mjs +1 -0
  409. package/dist/tools/index.d.mts +835 -0
  410. package/dist/tools/index.mjs +1 -0
  411. package/dist/tools/testing/index.d.mts +53 -0
  412. package/dist/tools/testing/index.mjs +1 -0
  413. package/dist/tools-D-luYcDw.mjs +1431 -0
  414. package/dist/tray-menu-service-DuXq5k22.mjs +1 -0
  415. package/dist/types-BCMUtBj1.d.mts +1106 -0
  416. package/dist/types-C2Ob9zz_.d.mts +128 -0
  417. package/dist/types-CCdqjeuH.d.mts +262 -0
  418. package/dist/types-DZHvOc_Q.d.mts +305 -0
  419. package/dist/types-Dy3YTcTF.d.mts +6777 -0
  420. package/dist/types-MfJZ67e9.d.mts +315 -0
  421. package/dist/types-dyP-bXXE.d.mts +31 -0
  422. package/dist/ui-components/index.d.mts +2342 -0
  423. package/dist/ui-components/index.mjs +8 -0
  424. package/dist/ui-config-9bDRwFZr.mjs +1 -0
  425. package/dist/ui-hooks/index.d.mts +1915 -0
  426. package/dist/ui-hooks/index.mjs +1 -0
  427. package/dist/ui-kernel/index.d.mts +2793 -0
  428. package/dist/ui-kernel/index.mjs +1 -0
  429. package/dist/ui-kernel/pages/namespace.d.mts +88 -0
  430. package/dist/ui-kernel/pages/namespace.mjs +1 -0
  431. package/dist/ui-kernel/pages/schemas.d.mts +2 -0
  432. package/dist/ui-kernel/pages/schemas.mjs +1 -0
  433. package/dist/ui-views/index.d.mts +487 -0
  434. package/dist/ui-views/index.mjs +30 -0
  435. package/dist/utils/health-probe.d.mts +26 -0
  436. package/dist/utils/health-probe.mjs +1 -0
  437. package/dist/utils/index.d.mts +262 -0
  438. package/dist/utils/index.mjs +2 -0
  439. package/dist/utils/keychain.d.mts +31 -0
  440. package/dist/utils/keychain.mjs +1 -0
  441. package/dist/utils/project-manifest.d.mts +130 -0
  442. package/dist/utils/project-manifest.mjs +1 -0
  443. package/dist/utils/resolve-package-root.d.mts +12 -0
  444. package/dist/utils/resolve-package-root.mjs +1 -0
  445. package/dist/utils/scope-paths.d.mts +33 -0
  446. package/dist/utils/scope-paths.mjs +1 -0
  447. package/dist/utils/workspace-packages.d.mts +59 -0
  448. package/dist/utils/workspace-packages.mjs +1 -0
  449. package/dist/utils/workspace-root.d.mts +24 -0
  450. package/dist/utils/workspace-root.mjs +2 -0
  451. package/dist/variant-CT6XBP6T.mjs +1 -0
  452. package/dist/version-BeT3ASEe.mjs +1 -0
  453. package/dist/visibility-Cb62p9bv.mjs +1 -0
  454. package/dist/window-registry-CBcrGTv4.d.mts +130 -0
  455. package/dist/window-registry-DW-dKRjQ.mjs +1 -0
  456. package/package.json +1 -1
@@ -0,0 +1,3 @@
1
+ import{spawn as e}from"node:child_process";import{Readable as t,Writable as n}from"node:stream";import{z as r}from"zod/v4";const i={authenticate:`authenticate`,document_did_change:`document/didChange`,document_did_close:`document/didClose`,document_did_focus:`document/didFocus`,document_did_open:`document/didOpen`,document_did_save:`document/didSave`,initialize:`initialize`,logout:`logout`,nes_accept:`nes/accept`,nes_close:`nes/close`,nes_reject:`nes/reject`,nes_start:`nes/start`,nes_suggest:`nes/suggest`,providers_disable:`providers/disable`,providers_list:`providers/list`,providers_set:`providers/set`,session_cancel:`session/cancel`,session_close:`session/close`,session_fork:`session/fork`,session_list:`session/list`,session_load:`session/load`,session_new:`session/new`,session_prompt:`session/prompt`,session_resume:`session/resume`,session_set_config_option:`session/set_config_option`,session_set_mode:`session/set_mode`,session_set_model:`session/set_model`},a={elicitation_complete:`elicitation/complete`,elicitation_create:`elicitation/create`,fs_read_text_file:`fs/read_text_file`,fs_write_text_file:`fs/write_text_file`,session_request_permission:`session/request_permission`,session_update:`session/update`,terminal_create:`terminal/create`,terminal_kill:`terminal/kill`,terminal_output:`terminal/output`,terminal_release:`terminal/release`,terminal_wait_for_exit:`terminal/wait_for_exit`},o=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),terminal:r.boolean().optional().default(!1)}),s=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),label:r.string().nullish(),name:r.string(),optional:r.boolean().optional().default(!1),secret:r.boolean().optional().default(!0)}),ee=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),description:r.string().nullish(),id:r.string(),name:r.string()}),te=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),description:r.string().nullish(),id:r.string(),link:r.string().nullish(),name:r.string(),vars:r.array(s)}),ne=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),args:r.array(r.string()).optional(),description:r.string().nullish(),env:r.record(r.string(),r.string()).optional(),id:r.string(),name:r.string()}),re=r.union([te.and(r.object({type:r.literal(`env_var`)})),ne.and(r.object({type:r.literal(`terminal`)})),ee]),ie=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),methodId:r.string()}),ae=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),oe=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),blob:r.string(),mimeType:r.string().nullish(),uri:r.string()}),se=r.object({default:r.boolean().nullish(),description:r.string().nullish(),title:r.string().nullish()}),ce=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),le=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),ue=r.object({amount:r.number(),currency:r.string()}),de=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),terminalId:r.string()}),fe=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),newText:r.string(),oldText:r.string().nullish(),path:r.string()}),pe=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),id:r.string()}),me=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),he=r.union([r.string(),r.number(),r.number(),r.boolean(),r.array(r.string())]),ge=r.object({content:r.record(r.string(),he).nullish()}),_e=r.intersection(r.union([ge.and(r.object({action:r.literal(`accept`)})),r.object({action:r.literal(`decline`)}),r.object({action:r.literal(`cancel`)})]),r.object({_meta:r.record(r.string(),r.unknown()).nullish()})),ve=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),c=r.string(),l=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),elicitationId:c}),ye=r.literal(`object`),be=r.literal(`string`),xe=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Se=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),form:ve.nullish(),url:xe.nullish()}),u=r.object({const:r.string(),title:r.string()}),Ce=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),name:r.string(),value:r.string()}),we=r.union([r.literal(-32700),r.literal(-32600),r.literal(-32601),r.literal(-32602),r.literal(-32603),r.literal(-32800),r.literal(-32e3),r.literal(-32002),r.literal(-32042),r.number().int().min(-2147483648,{message:`Invalid value: Expected int32 to be >= -2147483648`}).max(2147483647,{message:`Invalid value: Expected int32 to be <= 2147483647`})]),d=r.object({code:we,data:r.unknown().optional(),message:r.string()}),Te=r.unknown(),f=r.unknown(),p=r.unknown(),Ee=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),readTextFile:r.boolean().optional().default(!1),writeTextFile:r.boolean().optional().default(!1)}),m=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),name:r.string(),value:r.string()}),h=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),name:r.string(),title:r.string().nullish(),version:r.string()}),De=r.object({default:r.number().nullish(),description:r.string().nullish(),maximum:r.number().nullish(),minimum:r.number().nullish(),title:r.string().nullish()}),Oe=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),ke=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Ae=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),additionalDirectories:r.array(r.string()).optional(),cursor:r.string().nullish(),cwd:r.string().nullish()}),g=r.union([r.literal(`anthropic`),r.literal(`openai`),r.literal(`azure`),r.literal(`vertex`),r.literal(`bedrock`),r.string()]),je=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Me=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),logout:je.nullish()}),Ne=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Pe=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Fe=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),http:r.boolean().optional().default(!1),sse:r.boolean().optional().default(!1)}),Ie=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),headers:r.array(m),name:r.string(),url:r.string()}),Le=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),headers:r.array(m),name:r.string(),url:r.string()}),Re=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),args:r.array(r.string()),command:r.string(),env:r.array(Ce),name:r.string()}),_=r.union([Ie.and(r.object({type:r.literal(`http`)})),Le.and(r.object({type:r.literal(`sse`)})),Re]),v=r.string(),ze=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),description:r.string().nullish(),modelId:v,name:r.string()}),Be=r.union([r.literal(`error`),r.literal(`warning`),r.literal(`information`),r.literal(`hint`)]),Ve=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),He=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Ue=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),We=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Ge=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Ke=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),maxCount:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish()}),qe=r.object({diff:r.string(),uri:r.string()}),Je=r.object({endLine:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}),startLine:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}),text:r.string()}),Ye=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Xe=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Ze=r.object({languageId:r.string(),text:r.string(),uri:r.string()}),Qe=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),maxCount:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish()}),$e=r.union([r.literal(`rejected`),r.literal(`ignored`),r.literal(`replaced`),r.literal(`cancelled`)]),et=r.object({excerpts:r.array(Je),uri:r.string()}),tt=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),nt=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),rt=r.object({name:r.string(),owner:r.string(),remoteUrl:r.string()}),it=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),at=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),jump:Ye.nullish(),rename:nt.nullish(),searchAndReplace:it.nullish()}),ot=r.object({id:r.string(),isRegex:r.boolean().nullish(),replace:r.string(),search:r.string(),uri:r.string()}),st=r.union([r.literal(`automatic`),r.literal(`diagnostic`),r.literal(`manual`)]),ct=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),maxCount:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish()}),lt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),diagnostics:Ve.nullish(),editHistory:Ke.nullish(),openFiles:Xe.nullish(),recentFiles:Qe.nullish(),relatedSnippets:tt.nullish(),userActions:ct.nullish()}),ut=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),additionalDirectories:r.array(r.string()).optional(),cwd:r.string(),mcpServers:r.array(_)}),dt=r.object({default:r.number().nullish(),description:r.string().nullish(),maximum:r.number().nullish(),minimum:r.number().nullish(),title:r.string().nullish()}),y=r.string(),ft=r.union([r.literal(`allow_once`),r.literal(`allow_always`),r.literal(`reject_once`),r.literal(`reject_always`)]),pt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),kind:ft,name:r.string(),optionId:y}),mt=r.union([r.literal(`high`),r.literal(`medium`),r.literal(`low`)]),ht=r.union([r.literal(`pending`),r.literal(`in_progress`),r.literal(`completed`)]),gt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),content:r.string(),priority:mt,status:ht}),_t=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),entries:r.array(gt)}),b=r.object({character:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}),line:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`})}),vt=r.object({id:r.string(),position:b,uri:r.string()}),yt=r.object({id:r.string(),newName:r.string(),position:b,uri:r.string()}),bt=r.object({action:r.string(),position:b,timestampMs:r.number(),uri:r.string()}),x=r.union([r.literal(`utf-16`),r.literal(`utf-32`),r.literal(`utf-8`)]),xt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),auth:o.optional().default({terminal:!1}),elicitation:Se.nullish(),fs:Ee.optional().default({readTextFile:!1,writeTextFile:!1}),nes:at.nullish(),positionEncodings:r.array(x).optional(),terminal:r.boolean().optional().default(!1)}),St=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),audio:r.boolean().optional().default(!1),embeddedContext:r.boolean().optional().default(!1),image:r.boolean().optional().default(!1)}),S=r.number().int().gte(0).lte(65535),Ct=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),clientCapabilities:xt.optional().default({auth:{terminal:!1},fs:{readTextFile:!1,writeTextFile:!1},terminal:!1}),clientInfo:h.nullish(),protocolVersion:S}),wt=r.object({apiType:g,baseUrl:r.string()}),Tt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),current:wt.nullish(),id:r.string(),required:r.boolean(),supported:r.array(g)}),Et=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),providers:r.array(Tt)}),Dt=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),C=r.object({end:b,start:b}),Ot=r.object({message:r.string(),range:C,severity:Be,uri:r.string()}),kt=r.object({languageId:r.string(),lastFocusedMs:r.number().nullish(),uri:r.string(),visibleRange:C.nullish()}),At=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),diagnostics:r.array(Ot).nullish(),editHistory:r.array(qe).nullish(),openFiles:r.array(kt).nullish(),recentFiles:r.array(Ze).nullish(),relatedSnippets:r.array(et).nullish(),userActions:r.array(bt).nullish()}),jt=r.object({newText:r.string(),range:C}),Mt=r.object({cursorPosition:b.nullish(),edits:r.array(jt),id:r.string(),uri:r.string()}),Nt=r.union([Mt.and(r.object({kind:r.literal(`edit`)})),vt.and(r.object({kind:r.literal(`jump`)})),yt.and(r.object({kind:r.literal(`rename`)})),ot.and(r.object({kind:r.literal(`searchAndReplace`)}))]),Pt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),content:r.string()}),Ft=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),w=r.union([r.number(),r.string()]).nullable();r.object({_meta:r.record(r.string(),r.unknown()).nullish(),requestId:w});const T=r.object({requestId:w}),It=r.enum([`assistant`,`user`]),E=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),audience:r.array(It).nullish(),lastModified:r.string().nullish(),priority:r.number().nullish()}),Lt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),annotations:E.nullish(),data:r.string(),mimeType:r.string()}),Rt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),annotations:E.nullish(),data:r.string(),mimeType:r.string(),uri:r.string().nullish()}),zt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),annotations:E.nullish(),description:r.string().nullish(),mimeType:r.string().nullish(),name:r.string(),size:r.number().nullish(),title:r.string().nullish(),uri:r.string()}),Bt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),optionId:y}),Vt=r.union([r.object({outcome:r.literal(`cancelled`)}),Bt.and(r.object({outcome:r.literal(`selected`)}))]),Ht=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),outcome:Vt}),Ut=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Wt=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Gt=r.object({currentValue:r.boolean()}),Kt=r.string(),D=r.string(),qt=r.union([r.literal(`mode`),r.literal(`model`),r.literal(`thought_level`),r.string()]),O=r.string(),k=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),description:r.string().nullish(),name:r.string(),value:O}),Jt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),group:Kt,name:r.string(),options:r.array(k)}),Yt=r.union([r.array(k),r.array(Jt)]),Xt=r.object({currentValue:O,options:Yt}),A=r.intersection(r.union([Xt.and(r.object({type:r.literal(`select`)})),Gt.and(r.object({type:r.literal(`boolean`)}))]),r.object({_meta:r.record(r.string(),r.unknown()).nullish(),category:qt.nullish(),description:r.string().nullish(),id:D,name:r.string()})),Zt=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),configOptions:r.array(A)}),Qt=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),j=r.string(),$t=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),id:r.string(),sessionId:j}),en=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j}),tn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j}),nn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j}),M=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),args:r.array(r.string()).optional(),command:r.string(),cwd:r.string().nullish(),env:r.array(Ce).optional(),outputByteLimit:r.number().nullish(),sessionId:j}),rn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j,uri:r.string()}),an=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),position:b,sessionId:j,uri:r.string(),version:r.number(),visibleRange:C}),on=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),languageId:r.string(),sessionId:j,text:r.string(),uri:r.string(),version:r.number()}),sn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j,uri:r.string()}),cn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),additionalDirectories:r.array(r.string()).optional(),cwd:r.string(),mcpServers:r.array(_).optional(),sessionId:j}),N=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j,terminalId:r.string()}),ln=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),additionalDirectories:r.array(r.string()).optional(),cwd:r.string(),mcpServers:r.array(_),sessionId:j}),P=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),limit:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish(),line:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish(),path:r.string(),sessionId:j}),un=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),id:r.string(),reason:$e.nullish(),sessionId:j}),F=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j,terminalId:r.string()}),dn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),additionalDirectories:r.array(r.string()).optional(),cwd:r.string(),mcpServers:r.array(_).optional(),sessionId:j}),fn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),additionalDirectories:r.array(r.string()).optional(),cwd:r.string(),sessionId:j,title:r.string().nullish(),updatedAt:r.string().nullish()}),pn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),nextCursor:r.string().nullish(),sessions:r.array(fn)}),mn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),title:r.string().nullish(),updatedAt:r.string().nullish()}),hn=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),I=r.string(),gn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),currentModeId:I}),_n=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),description:r.string().nullish(),id:I,name:r.string()}),L=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),availableModes:r.array(_n),currentModeId:I}),R=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),availableModels:r.array(ze),currentModelId:v}),vn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),configOptions:r.array(A).nullish(),models:R.nullish(),modes:L.nullish(),sessionId:j}),yn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),configOptions:r.array(A).nullish(),models:R.nullish(),modes:L.nullish()}),bn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),configOptions:r.array(A).nullish(),models:R.nullish(),modes:L.nullish(),sessionId:j}),xn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),configOptions:r.array(A).nullish(),models:R.nullish(),modes:L.nullish()}),Sn=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Cn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),additionalDirectories:Ut.nullish(),close:Wt.nullish(),fork:Qt.nullish(),list:hn.nullish(),resume:Sn.nullish()}),wn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),apiType:g,baseUrl:r.string(),headers:r.record(r.string(),r.string()).optional(),id:r.string()}),Tn=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),En=r.intersection(r.union([r.object({type:r.literal(`boolean`),value:r.boolean()}),r.object({value:O})]),r.object({_meta:r.record(r.string(),r.unknown()).nullish(),configId:D,sessionId:j})),Dn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),configOptions:r.array(A)}),On=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),modeId:I,sessionId:j}),kn=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),An=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),modelId:v,sessionId:j}),jn=r.object({_meta:r.record(r.string(),r.unknown()).nullish()}),Mn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j}),Nn=r.union([r.literal(`end_turn`),r.literal(`max_tokens`),r.literal(`max_turn_requests`),r.literal(`refusal`),r.literal(`cancelled`)]),Pn=r.union([r.literal(`email`),r.literal(`uri`),r.literal(`date`),r.literal(`date-time`)]),Fn=r.object({default:r.string().nullish(),description:r.string().nullish(),enum:r.array(r.string()).nullish(),format:Pn.nullish(),maxLength:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish(),minLength:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish(),oneOf:r.array(u).nullish(),pattern:r.string().nullish(),title:r.string().nullish()}),In=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),context:At.nullish(),position:b,selection:C.nullish(),sessionId:j,triggerKind:st,uri:r.string(),version:r.number()}),Ln=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),suggestions:r.array(Nt)}),Rn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),terminalId:r.string()}),zn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),exitCode:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish(),signal:r.string().nullish()}),z=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j,terminalId:r.string()}),Bn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),exitStatus:zn.nullish(),output:r.string(),truncated:r.boolean()}),Vn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),annotations:E.nullish(),text:r.string()}),Hn=r.object({range:C.nullish(),text:r.string()}),Un=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),contentChanges:r.array(Hn),sessionId:j,uri:r.string(),version:r.number()});r.object({method:r.string(),params:r.union([en,on,Un,rn,sn,an,$t,un,Te]).nullish()});const Wn=r.union([r.literal(`full`),r.literal(`incremental`)]),Gn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),syncKind:Wn}),Kn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),didChange:Gn.nullish(),didClose:He.nullish(),didFocus:Ue.nullish(),didOpen:We.nullish(),didSave:Ge.nullish()}),qn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),document:Kn.nullish()}),Jn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),context:lt.nullish(),events:qn.nullish()}),Yn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),auth:Me.optional().default({}),loadSession:r.boolean().optional().default(!1),mcpCapabilities:Fe.optional().default({http:!1,sse:!1}),nes:Jn.nullish(),positionEncoding:x.nullish(),promptCapabilities:St.optional().default({audio:!1,embeddedContext:!1,image:!1}),providers:Dt.nullish(),sessionCapabilities:Cn.optional().default({})}),Xn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),agentCapabilities:Yn.optional().default({auth:{},loadSession:!1,mcpCapabilities:{http:!1,sse:!1},promptCapabilities:{audio:!1,embeddedContext:!1,image:!1},sessionCapabilities:{}}),agentInfo:h.nullish(),authMethods:r.array(re).optional().default([]),protocolVersion:S}),Zn=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),mimeType:r.string().nullish(),text:r.string(),uri:r.string()}),Qn=r.union([Zn,oe]),$n=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),annotations:E.nullish(),resource:Qn}),B=r.union([Vn.and(r.object({type:r.literal(`text`)})),Rt.and(r.object({type:r.literal(`image`)})),Lt.and(r.object({type:r.literal(`audio`)})),zt.and(r.object({type:r.literal(`resource_link`)})),$n.and(r.object({type:r.literal(`resource`)}))]),er=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),content:B}),V=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),content:B,messageId:r.string().nullish()}),tr=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),messageId:r.string().nullish(),prompt:r.array(B),sessionId:j}),nr=r.object({anyOf:r.array(u)}),H=r.union([er.and(r.object({type:r.literal(`content`)})),fe.and(r.object({type:r.literal(`diff`)})),Rn.and(r.object({type:r.literal(`terminal`)}))]),U=r.string(),W=r.object({sessionId:j,toolCallId:U.nullish()}),rr=r.intersection(r.union([W,T]),r.object({elicitationId:c,url:r.string().url()})),G=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),line:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish(),path:r.string()}),K=r.union([r.literal(`pending`),r.literal(`in_progress`),r.literal(`completed`),r.literal(`failed`)]),q=r.union([r.literal(`read`),r.literal(`edit`),r.literal(`delete`),r.literal(`move`),r.literal(`search`),r.literal(`execute`),r.literal(`think`),r.literal(`fetch`),r.literal(`switch_mode`),r.literal(`other`)]),ir=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),content:r.array(H).optional(),kind:q.optional(),locations:r.array(G).optional(),rawInput:r.unknown().optional(),rawOutput:r.unknown().optional(),status:K.optional(),title:r.string(),toolCallId:U}),J=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),content:r.array(H).nullish(),kind:q.nullish(),locations:r.array(G).nullish(),rawInput:r.unknown().optional(),rawOutput:r.unknown().optional(),status:K.nullish(),title:r.string().nullish(),toolCallId:U}),Y=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),options:r.array(pt),sessionId:j,toolCall:J}),ar=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),hint:r.string()}),or=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),description:r.string(),input:ar.nullish(),name:r.string()}),sr=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),availableCommands:r.array(or)}),cr=r.object({enum:r.array(r.string()),type:be}),lr=r.union([cr,nr]),ur=r.object({default:r.array(r.string()).nullish(),description:r.string().nullish(),items:lr,maxItems:r.number().nullish(),minItems:r.number().nullish(),title:r.string().nullish()}),dr=r.union([Fn.and(r.object({type:r.literal(`string`)})),dt.and(r.object({type:r.literal(`number`)})),De.and(r.object({type:r.literal(`integer`)})),se.and(r.object({type:r.literal(`boolean`)})),ur.and(r.object({type:r.literal(`array`)}))]),fr=r.object({description:r.string().nullish(),properties:r.record(r.string(),dr).optional().default({}),required:r.array(r.string()).nullish(),title:r.string().nullish(),type:ye.optional().default(`object`)}),pr=r.intersection(r.union([W,T]),r.object({requestedSchema:fr})),X=r.intersection(r.union([pr.and(r.object({mode:r.literal(`form`)})),rr.and(r.object({mode:r.literal(`url`)}))]),r.object({_meta:r.record(r.string(),r.unknown()).nullish(),message:r.string()})),mr=r.object({cachedReadTokens:r.number().nullish(),cachedWriteTokens:r.number().nullish(),inputTokens:r.number(),outputTokens:r.number(),thoughtTokens:r.number().nullish(),totalTokens:r.number()}),hr=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),stopReason:Nn,usage:mr.nullish(),userMessageId:r.string().nullish()});r.union([r.object({id:w,result:r.union([Xn,ae,Et,Tn,me,Pe,bn,yn,pn,vn,xn,le,kn,Dn,hr,jn,Mn,Ln,ce,p])}),r.object({error:d,id:w})]);const gr=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),cost:ue.nullish(),size:r.number(),used:r.number()}),_r=r.union([V.and(r.object({sessionUpdate:r.literal(`user_message_chunk`)})),V.and(r.object({sessionUpdate:r.literal(`agent_message_chunk`)})),V.and(r.object({sessionUpdate:r.literal(`agent_thought_chunk`)})),ir.and(r.object({sessionUpdate:r.literal(`tool_call`)})),J.and(r.object({sessionUpdate:r.literal(`tool_call_update`)})),_t.and(r.object({sessionUpdate:r.literal(`plan`)})),sr.and(r.object({sessionUpdate:r.literal(`available_commands_update`)})),gn.and(r.object({sessionUpdate:r.literal(`current_mode_update`)})),Zt.and(r.object({sessionUpdate:r.literal(`config_option_update`)})),mn.and(r.object({sessionUpdate:r.literal(`session_info_update`)})),gr.and(r.object({sessionUpdate:r.literal(`usage_update`)}))]),Z=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j,update:_r});r.object({method:r.string(),params:r.union([Z,l,Te]).nullish()});const Q=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),sessionId:j,terminalId:r.string()}),vr=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),exitCode:r.number().int().gte(0).max(4294967295,{message:`Invalid value: Expected uint32 to be <= 4294967295`}).nullish(),signal:r.string().nullish()}),yr=r.object({name:r.string(),uri:r.string()}),br=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),repository:rt.nullish(),workspaceFolders:r.array(yr).nullish(),workspaceUri:r.string().nullish()});r.object({id:w,method:r.string(),params:r.union([Ct,ie,ke,wn,pe,Ne,ut,ln,Ae,cn,dn,nn,On,En,tr,An,br,In,tn,f]).nullish()});const xr=r.object({_meta:r.record(r.string(),r.unknown()).nullish(),content:r.string(),path:r.string(),sessionId:j});r.object({id:w,method:r.string(),params:r.union([xr,P,Y,M,z,F,Q,N,X,f]).nullish()});const Sr=r.object({_meta:r.record(r.string(),r.unknown()).nullish()});r.union([r.object({id:w,result:r.union([Sr,Pt,Ht,de,Bn,Ft,vr,Oe,_e,p])}),r.object({error:d,id:w})]);function Cr(e,t){let n=new TextEncoder,r=new TextDecoder;return{readable:new ReadableStream({async start(e){let n=``,i=t.getReader();try{for(;;){let{value:t,done:a}=await i.read();if(a){n+=r.decode();break}if(!t)continue;n+=r.decode(t,{stream:!0});let o=n.split(`
2
+ `);n=o.pop()||``;for(let t of o){let n=t.trim();if(n)try{let t=JSON.parse(n);e.enqueue(t)}catch(e){console.error(`Failed to parse JSON message:`,n,e)}}}let t=n.trim();if(t)try{let n=JSON.parse(t);e.enqueue(n)}catch(e){console.error(`Failed to parse JSON message:`,t,e)}}catch(t){e.error(t);return}finally{i.releaseLock()}e.close()}}),writable:new WritableStream({async write(t){let r=JSON.stringify(t)+`
3
+ `,i=e.getWriter();try{await i.write(n.encode(r))}finally{i.releaseLock()}}})}}var wr=class{connection;constructor(e,t){let n=e(this),r=async(e,t)=>{switch(e){case a.fs_write_text_file:{let e=xr.parse(t);return n.writeTextFile?.(e)}case a.fs_read_text_file:{let e=P.parse(t);return n.readTextFile?.(e)}case a.session_request_permission:{let e=Y.parse(t);return n.requestPermission(e)}case a.terminal_create:{let e=M.parse(t);return n.createTerminal?.(e)}case a.terminal_output:{let e=z.parse(t);return n.terminalOutput?.(e)}case a.terminal_release:{let e=F.parse(t);return await n.releaseTerminal?.(e)??{}}case a.terminal_wait_for_exit:{let e=Q.parse(t);return n.waitForTerminalExit?.(e)}case a.terminal_kill:{let e=N.parse(t);return await n.killTerminal?.(e)??{}}case a.elicitation_create:{if(!n.unstable_createElicitation)throw $.methodNotFound(e);let r=X.parse(t);return n.unstable_createElicitation(r)}default:if(n.extMethod)return n.extMethod(e,t);throw $.methodNotFound(e)}},i=async(e,t)=>{switch(e){case a.session_update:{let e=Z.parse(t);return n.sessionUpdate(e)}case a.elicitation_complete:{if(!n.unstable_completeElicitation)return;let e=l.parse(t);return n.unstable_completeElicitation(e)}default:if(n.extNotification)return n.extNotification(e,t);throw $.methodNotFound(e)}};this.connection=new Tr(r,i,t)}async initialize(e){return await this.connection.sendRequest(i.initialize,e)}async newSession(e){return await this.connection.sendRequest(i.session_new,e)}async loadSession(e){return await this.connection.sendRequest(i.session_load,e)??{}}async unstable_forkSession(e){return await this.connection.sendRequest(i.session_fork,e)}async listSessions(e){return await this.connection.sendRequest(i.session_list,e)}async resumeSession(e){return await this.connection.sendRequest(i.session_resume,e)}async closeSession(e){return await this.connection.sendRequest(i.session_close,e)}async setSessionMode(e){return await this.connection.sendRequest(i.session_set_mode,e)??{}}async unstable_setSessionModel(e){return await this.connection.sendRequest(i.session_set_model,e)??{}}async setSessionConfigOption(e){return await this.connection.sendRequest(i.session_set_config_option,e)}async authenticate(e){return await this.connection.sendRequest(i.authenticate,e)??{}}async unstable_listProviders(e){return await this.connection.sendRequest(i.providers_list,e)}async unstable_setProvider(e){return await this.connection.sendRequest(i.providers_set,e)??{}}async unstable_disableProvider(e){return await this.connection.sendRequest(i.providers_disable,e)??{}}async unstable_logout(e){return await this.connection.sendRequest(i.logout,e)??{}}async prompt(e){return await this.connection.sendRequest(i.session_prompt,e)}async cancel(e){return await this.connection.sendNotification(i.session_cancel,e)}async unstable_startNes(e){return await this.connection.sendRequest(i.nes_start,e)}async unstable_suggestNes(e){return await this.connection.sendRequest(i.nes_suggest,e)}async unstable_closeNes(e){return await this.connection.sendRequest(i.nes_close,e)??{}}async unstable_didOpenDocument(e){return await this.connection.sendNotification(i.document_did_open,e)}async unstable_didChangeDocument(e){return await this.connection.sendNotification(i.document_did_change,e)}async unstable_didCloseDocument(e){return await this.connection.sendNotification(i.document_did_close,e)}async unstable_didSaveDocument(e){return await this.connection.sendNotification(i.document_did_save,e)}async unstable_didFocusDocument(e){return await this.connection.sendNotification(i.document_did_focus,e)}async unstable_acceptNes(e){return await this.connection.sendNotification(i.nes_accept,e)}async unstable_rejectNes(e){return await this.connection.sendNotification(i.nes_reject,e)}async extMethod(e,t){return await this.connection.sendRequest(e,t)}async extNotification(e,t){return await this.connection.sendNotification(e,t)}get signal(){return this.connection.signal}get closed(){return this.connection.closed}},Tr=class{pendingResponses=new Map;nextRequestId=0;requestHandler;notificationHandler;stream;writeQueue=Promise.resolve();abortController=new AbortController;closedPromise;constructor(e,t,n){this.requestHandler=e,this.notificationHandler=t,this.stream=n,this.closedPromise=new Promise(e=>{this.abortController.signal.addEventListener(`abort`,()=>e())}),this.receive()}get signal(){return this.abortController.signal}get closed(){return this.closedPromise}async receive(){let e;try{let e=this.stream.readable.getReader();try{for(;!this.abortController.signal.aborted;){let{value:t,done:n}=await e.read();if(n)break;if(t)try{this.processMessage(t)}catch(e){console.error(`Unexpected error during message processing:`,t,e),`id`in t&&t.id!==void 0&&this.sendMessage({jsonrpc:`2.0`,id:t.id,error:{code:-32700,message:`Parse error`}})}}}finally{e.releaseLock()}}catch(t){e=t}finally{this.close(e)}}close(e){if(this.abortController.signal.aborted)return;let t=e??Error(`ACP connection closed`);for(let e of this.pendingResponses.values())e.reject(t);this.pendingResponses.clear(),this.abortController.abort(t)}async processMessage(e){if(`method`in e&&`id`in e){let t=await this.tryCallRequestHandler(e.method,e.params);`error`in t&&console.error(`Error handling request`,e,t.error),await this.sendMessage({jsonrpc:`2.0`,id:e.id,...t})}else if(`method`in e){let t=await this.tryCallNotificationHandler(e.method,e.params);`error`in t&&console.error(`Error handling notification`,e,t.error)}else `id`in e?this.handleResponse(e):console.error(`Invalid message`,{message:e})}async tryCallRequestHandler(e,t){try{return{result:await this.requestHandler(e,t)??null}}catch(e){if(e instanceof $)return e.toResult();if(e instanceof r.ZodError)return $.invalidParams(e.format()).toResult();let t;(e instanceof Error||typeof e==`object`&&e&&`message`in e&&typeof e.message==`string`)&&(t=e.message);try{return $.internalError(t?JSON.parse(t):{}).toResult()}catch{return $.internalError({details:t}).toResult()}}}async tryCallNotificationHandler(e,t){try{return await this.notificationHandler(e,t),{result:null}}catch(e){if(e instanceof $)return e.toResult();if(e instanceof r.ZodError)return $.invalidParams(e.format()).toResult();let t;(e instanceof Error||typeof e==`object`&&e&&`message`in e&&typeof e.message==`string`)&&(t=e.message);try{return $.internalError(t?JSON.parse(t):{}).toResult()}catch{return $.internalError({details:t}).toResult()}}}handleResponse(e){let t=this.pendingResponses.get(e.id);if(t){if(`result`in e)t.resolve(e.result);else if(`error`in e){let{code:n,message:r,data:i}=e.error;t.reject(new $(n,r,i))}this.pendingResponses.delete(e.id)}else console.error(`Got response to unknown request`,e.id)}sendRequest(e,t){this.throwIfClosed();let n=this.nextRequestId++,r=new Promise((e,t)=>{this.pendingResponses.set(n,{resolve:e,reject:t})});return r.catch(()=>{}),this.sendMessage({jsonrpc:`2.0`,id:n,method:e,params:t}),r}async sendNotification(e,t){this.throwIfClosed(),await this.sendMessage({jsonrpc:`2.0`,method:e,params:t})}throwIfClosed(){if(this.abortController.signal.aborted)throw this.abortController.signal.reason??Error(`ACP connection closed`)}async sendMessage(e){return this.writeQueue=this.writeQueue.then(async()=>{let t=this.stream.writable.getWriter();try{await t.write(e)}finally{t.releaseLock()}}).catch(e=>{this.close(e)}),this.writeQueue}},$=class e extends Error{code;data;constructor(e,t,n){super(t),this.code=e,this.name=`RequestError`,this.data=n}static parseError(t,n){return new e(-32700,`Parse error${n?`: ${n}`:``}`,t)}static invalidRequest(t,n){return new e(-32600,`Invalid request${n?`: ${n}`:``}`,t)}static methodNotFound(t){return new e(-32601,`"Method not found": ${t}`,{method:t})}static invalidParams(t,n){return new e(-32602,`Invalid params${n?`: ${n}`:``}`,t)}static internalError(t,n){return new e(-32603,`Internal error${n?`: ${n}`:``}`,t)}static authRequired(t,n){return new e(-32e3,`Authentication required${n?`: ${n}`:``}`,t)}static resourceNotFound(t){return new e(-32002,`Resource not found${t?`: ${t}`:``}`,t&&{uri:t})}toResult(){return{error:{code:this.code,message:this.message,data:this.data}}}toErrorResponse(){return{code:this.code,message:this.message,data:this.data}}};function Er(e){return new Promise((t,n)=>{let r=()=>{e.off(`error`,i),t()},i=t=>{e.off(`spawn`,r),n(t)};e.once(`spawn`,r),e.once(`error`,i)})}async function Dr(e){e.stdin?.destroy(),e.stdout?.destroy(),e.stderr?.destroy(),e.kill(`SIGTERM`),await new Promise(t=>{e.once(`exit`,()=>t()),e.once(`close`,()=>t()),setTimeout(t,100)})}function Or(e){return e}function kr(e){return e}async function Ar(r,i){let a=e(i.command,i.args,{cwd:i.cwd,env:i.env,stdio:[`pipe`,`pipe`,`pipe`]});try{await Er(a)}catch(e){throw i.onError?.(e),e}i.onStderr&&a.stderr&&a.stderr.on(`data`,e=>{i.onStderr(e.toString(`utf-8`))});let o=new Promise(e=>{a.once(`exit`,t=>{i.onExit?.(t),e(t)})});a.on(`error`,e=>{i.onError?.(e)});let s;try{let e=t.toWeb(a.stdout);s=new wr(r,Cr(kr(n.toWeb(a.stdin)),Or(e)))}catch(e){throw await Dr(a),e}return{connection:s,kill:()=>a.kill(`SIGTERM`),exited:o}}var jr=class{config;constructor(e){this.config=e}async sessionUpdate(e){await this.config.onSessionUpdate(e)}async requestPermission(e){return this.config.onRequestPermission(e)}async readTextFile(e){if(!this.config.onReadTextFile)throw Error(`readTextFile not supported: no handler configured`);return this.config.onReadTextFile(e)}async writeTextFile(e){if(!this.config.onWriteTextFile)throw Error(`writeTextFile not supported: no handler configured`);return this.config.onWriteTextFile(e)}async createTerminal(e){if(!this.config.terminalManager)throw Error(`createTerminal not supported: no terminal manager configured`);return this.config.terminalManager.createTerminal(e)}async terminalOutput(e){if(!this.config.terminalManager)throw Error(`terminalOutput not supported: no terminal manager configured`);return this.config.terminalManager.getOutput(e)}async waitForTerminalExit(e){if(!this.config.terminalManager)throw Error(`waitForTerminalExit not supported: no terminal manager configured`);return this.config.terminalManager.waitForExit(e)}async killTerminal(e){if(!this.config.terminalManager)throw Error(`killTerminal not supported: no terminal manager configured`);return this.config.terminalManager.killTerminal(e)}async releaseTerminal(e){if(!this.config.terminalManager)throw Error(`releaseTerminal not supported: no terminal manager configured`);return this.config.terminalManager.releaseTerminal(e)}},Mr=class{terminals=new Map;nextId=0;async createTerminal(t){let n=`terminal-${(++this.nextId).toString()}`,r=t.outputByteLimit??1024*1024,i={...process.env};if(t.env)for(let e of t.env)i[e.name]=e.value;let a=e(t.command,t.args??[],{cwd:t.cwd??void 0,env:i,stdio:[`pipe`,`pipe`,`pipe`]});try{await Er(a)}catch(e){throw await Dr(a),e}let o={process:a,output:``,outputByteLimit:r,truncated:!1,exitCode:void 0,signal:void 0,hasExited:!1,exitPromise:new Promise(e=>{a.on(`exit`,(e,t)=>{o.exitCode=e,o.signal=t??null}),a.on(`close`,()=>{o.hasExited=!0,e({exitCode:o.exitCode??null,signal:o.signal??null})})})},s=e=>{if(o.output+=e.toString(`utf-8`),Buffer.byteLength(o.output,`utf-8`)>o.outputByteLimit){let e=Buffer.from(o.output,`utf-8`),t=e.length-o.outputByteLimit;for(;t<e.length&&(e[t]&192)==128;)t+=1;o.output=e.subarray(t).toString(`utf-8`),o.truncated=!0}};return a.stdout?.on(`data`,s),a.stderr?.on(`data`,s),this.terminals.set(n,o),{terminalId:n}}async getOutput(e){let t=this.requireTerminal(e.terminalId);return{output:t.output,truncated:t.truncated,...t.hasExited&&{exitStatus:{exitCode:t.exitCode??null,signal:t.signal??null}}}}async waitForExit(e){let{exitCode:t,signal:n}=await this.requireTerminal(e.terminalId).exitPromise;return{exitCode:t??void 0,signal:n??void 0}}async killTerminal(e){return this.requireTerminal(e.terminalId).process.kill(`SIGTERM`),{}}async releaseTerminal(e){let t=this.terminals.get(e.terminalId);return t&&(t.process.kill(`SIGKILL`),this.terminals.delete(e.terminalId)),{}}releaseAll(){for(let[e,t]of this.terminals)t.process.kill(`SIGKILL`),this.terminals.delete(e)}requireTerminal(e){let t=this.terminals.get(e);if(!t)throw Error(`Terminal not found: ${e}`);return t}};export{jr as MakaioAcpClient,Mr as TerminalManager,Ar as createAcpConnection};
@@ -0,0 +1,429 @@
1
+ import { g as BaseAgentConnectorConfig } from "../../types-BCMUtBj1.mjs";
2
+ import { z } from "zod";
3
+ import { IMakaioBus, MakaioBusContext } from "@makaio/framework/bus";
4
+ import { AIModelSchema, ProtocolId, ProviderContext } from "@makaio/framework/contracts";
5
+ import { BaseAdapterConfigSchema, CredentialRef, ProviderConfigSchema, ProviderDefaultsSchema } from "@makaio/framework/contracts/config";
6
+ import { ClientExecutionContext } from "@makaio/framework/contracts/client";
7
+ import { ProviderRecord } from "@makaio/framework/services/settings/storage";
8
+ import { TimeoutConfig, TrackedTimeoutConfig } from "@makaio/framework/utils";
9
+ import { ProviderConfigFileRecord } from "@makaio/framework/services/adapter-subsystem";
10
+ import { Simplify } from "type-fest";
11
+
12
+ //#region adapters/core/src/config/resolve-credential-ref.d.ts
13
+ /**
14
+ * Dependency overrides for credential resolution.
15
+ */
16
+ interface ResolveCredentialRefDeps {
17
+ /** Read a file path for file: refs. */
18
+ readFile?: (path: string) => Promise<string>;
19
+ /** Read an environment variable for env: refs. */
20
+ readEnv?: (name: string) => string | undefined;
21
+ /** Resolve keychain credentials for keychain: refs. */
22
+ resolveKeychain?: (service: string, account: string) => Promise<string | null>;
23
+ }
24
+ /**
25
+ * Resolve a credential reference to its runtime value.
26
+ *
27
+ * Supported formats:
28
+ * - env:VAR_NAME
29
+ * - file:/path/to/secret
30
+ * - keychain:service:account (requires resolveKeychain)
31
+ * @param ref - Credential reference string
32
+ * @param deps - Optional dependency overrides for resolution
33
+ * @returns Resolved credential value or null if not found
34
+ */
35
+ declare function resolveCredentialRef(ref: CredentialRef, deps?: ResolveCredentialRefDeps): Promise<string | null>;
36
+ //#endregion
37
+ //#region adapters/core/src/config/preset.d.ts
38
+ /**
39
+ * Resolve a provider definition by ID and require a concrete `defaultModel`.
40
+ * @param definitions - Available provider definitions for an adapter.
41
+ * @param definitionId - Provider definition identifier to resolve.
42
+ * @returns The matching definition with a guaranteed `defaultModel`.
43
+ * @throws Error when the definition does not exist or does not define `defaultModel`.
44
+ */
45
+ declare function getDefinitionOrThrow<TDefinition extends {
46
+ id: string;
47
+ defaultModel?: string;
48
+ }>(definitions: TDefinition[], definitionId: string): TDefinition & {
49
+ defaultModel: string;
50
+ };
51
+ //#endregion
52
+ //#region adapters/core/src/config/schemas.d.ts
53
+ /**
54
+ * Base schema for adapter provider configuration.
55
+ *
56
+ * Adapters extend this schema to add provider-specific fields.
57
+ * All fields use `.describe()` to provide UI hints for form generation.
58
+ *
59
+ * This schema is intentionally empty - it serves as a type marker.
60
+ * Adapters define their own providerSettings fields.
61
+ * @example
62
+ * ```typescript
63
+ * // In adapter definition:
64
+ * const MyProviderSettingsSchema = BaseProviderSettingsSchema.extend({
65
+ * apiKey: z.string().describe('API key for authentication'),
66
+ * baseUrl: z.string().url().optional().describe('Custom API endpoint'),
67
+ * });
68
+ * ```
69
+ */
70
+ declare const BaseProviderConfigSchema: z.ZodRecord<z.ZodString, z.ZodUnknown>;
71
+ //#endregion
72
+ //#region adapters/core/src/config/types.d.ts
73
+ /**
74
+ * Base provider configuration type.
75
+ * Adapters extend this for their provider-specific fields.
76
+ */
77
+ type BaseProviderConfig = z.infer<typeof BaseProviderConfigSchema>;
78
+ /**
79
+ * AI model information type.
80
+ */
81
+ type AIModel = z.infer<typeof AIModelSchema>;
82
+ /**
83
+ * Provider defaults configuration type.
84
+ */
85
+ type ProviderDefaults = z.infer<typeof ProviderDefaultsSchema>;
86
+ /**
87
+ * Configuration for a single adapter provider.
88
+ */
89
+ type ProviderConfig = z.infer<typeof ProviderConfigSchema>;
90
+ /**
91
+ * Adapter configuration file structure.
92
+ * Stored at `~/.makaio/adapters/<adapterName>/config.json`.
93
+ */
94
+ type BaseAdapterConfig = z.infer<typeof BaseAdapterConfigSchema>;
95
+ //#endregion
96
+ //#region adapters/core/src/config/factory.d.ts
97
+ /**
98
+ * Adapter-level defaults that can be set by the factory.
99
+ * Generic over TConfig to get type-safe providerConfig.
100
+ * Excludes runtime fields (agentId, sessionId, adapterName).
101
+ * All fields optional — model comes from provider config at runtime.
102
+ */
103
+ type AdapterDefaults<TConfig extends BaseAgentConnectorConfig = BaseAgentConnectorConfig> = Partial<Omit<TConfig, 'agentId' | 'sessionId' | 'adapterName' | 'bus'>>;
104
+ /**
105
+ * Options for creating an adapter config factory.
106
+ * Captures the adapter-specific constants needed to resolve config.
107
+ * @typeParam TConfig - The adapter's full config type for type-safe defaults
108
+ */
109
+ interface CreateAdapterConfigFactoryOptions<TConfig extends BaseAgentConnectorConfig> {
110
+ /** Adapter type name (e.g., 'claude-code', 'gemini-sdk') */
111
+ adapterName: string;
112
+ /** Adapter-level defaults (model required, others optional including providerConfig) */
113
+ adapterDefaults: AdapterDefaults<TConfig>;
114
+ /**
115
+ * Optional Zod schema for provider config validation.
116
+ * Currently unused — pass `null`. Retained as an extension point for
117
+ * future runtime validation of merged provider config shapes.
118
+ */
119
+ schema: z.ZodObject<z.ZodRawShape> | null;
120
+ /** Adapter definition containing defaultTimeouts */
121
+ adapterDefinition: {
122
+ defaultTimeouts?: TimeoutConfig;
123
+ };
124
+ /** Wire protocol used to select the correct provider endpoint URL from endpointOverrides. */
125
+ protocol: ProtocolId;
126
+ }
127
+ /**
128
+ * Minimal input shape required by the factory.
129
+ * Adapters pass their full ConfigFactoryInput which extends this.
130
+ */
131
+ interface AdapterConfigFactoryInput<TConfig extends BaseAgentConnectorConfig> {
132
+ bus: TConfig extends BaseAgentConnectorConfig<infer TBus> ? TBus : never;
133
+ agentId: string;
134
+ adapterName: string;
135
+ adapterId: string;
136
+ /**
137
+ * Unresolved provider context (credential refs, not plaintext).
138
+ * Connectors resolve credentials locally via `resolveConnectorCredentials()`.
139
+ */
140
+ providerContext: ProviderContext;
141
+ model?: string;
142
+ cwd?: string;
143
+ env?: Record<string, string>;
144
+ providerConfig?: Partial<TConfig['providerConfig']>;
145
+ runtimeTimeouts?: TimeoutConfig;
146
+ }
147
+ /**
148
+ * Fields guaranteed by the factory (overrides any optional versions from input).
149
+ */
150
+ interface FactoryGuaranteedFields<TProviderConfig> {
151
+ adapterName: string;
152
+ model: string;
153
+ cwd: string;
154
+ timeouts: TrackedTimeoutConfig;
155
+ providerConfig: TProviderConfig;
156
+ }
157
+ /**
158
+ * Result type: input + adapter defaults + guaranteed fields.
159
+ * Simplify flattens the intersection for better type display.
160
+ */
161
+ type ConfigFactoryResult<TInput extends AdapterConfigFactoryInput<TConfig>, TConfig extends BaseAgentConnectorConfig, TProviderConfig = TConfig['providerConfig']> = Simplify<AdapterDefaults<TConfig> & Omit<TInput, 'providerConfig'> & FactoryGuaranteedFields<TProviderConfig>>;
162
+ type AdapterConfigFactory<TConfig extends BaseAgentConnectorConfig, TProviderConfig> = {
163
+ getConfig: <TInput extends AdapterConfigFactoryInput<TConfig>>(input: TInput) => Promise<ConfigFactoryResult<TInput, TConfig, TProviderConfig>>; /** Lazily evaluate the thunk and return adapter defaults (model, fastModel, etc.) */
164
+ getDefaults: () => AdapterDefaults<TConfig>;
165
+ };
166
+ /**
167
+ * Create a standardized adapter config factory.
168
+ *
169
+ * Eliminates ceremony by encapsulating the common pattern:
170
+ * 1. Read unresolved providerContext (credential refs only — no plaintext on the bus)
171
+ * 2. resolveTimeouts with adapter + runtime layers
172
+ * 3. Merge providerConfigDefaults with runtime providerConfig (credentials resolved by connector)
173
+ *
174
+ * The factory is pure: it does not dispatch any bus requests and does not
175
+ * resolve credentials. Connectors call `resolveConnectorCredentials()` locally.
176
+ *
177
+ * Options are provided via thunk to enable lazy evaluation, avoiding circular
178
+ * dependency issues when config.ts imports from index.ts (for adapterDefinition)
179
+ * and adapter.ts (for adapterName).
180
+ * @param optionsThunk - Thunk returning factory configuration options
181
+ * @returns Factory with getConfig method
182
+ * @example
183
+ * ```typescript
184
+ * export const GeminiSdkConfig = createAdapterConfigFactory<GeminiConnectorConfig>(() => ({
185
+ * adapterName: GeminiSdkAdapterName,
186
+ * adapterDefaults: { model: 'gemini-2.5-pro' },
187
+ * schema: null,
188
+ * adapterDefinition: { defaultTimeouts: DEFAULT_TIMEOUTS },
189
+ * protocol: 'openai',
190
+ * }));
191
+ * ```
192
+ */
193
+ declare function createAdapterConfigFactory<TConfig extends BaseAgentConnectorConfig, TProviderConfig = TConfig['providerConfig']>(optionsThunk: () => CreateAdapterConfigFactoryOptions<TConfig>): AdapterConfigFactory<TConfig, TProviderConfig>;
194
+ //#endregion
195
+ //#region adapters/core/src/config/resolve-provider-endpoint.d.ts
196
+ /**
197
+ * Resolved HTTP endpoint credentials for a provider.
198
+ * Returned by {@link resolveProviderEndpoint} for use by infrastructure-layer
199
+ * consumers (bridges, cloud STT/TTS clients, etc.) that need to make direct
200
+ * HTTP calls to a provider API without an agent context.
201
+ */
202
+ interface ProviderEndpoint {
203
+ /** Base URL for the provider's HTTP API. */
204
+ baseUrl: string;
205
+ /**
206
+ * API key for authenticating requests to the provider.
207
+ * This helper is intentionally scoped to apiKey-authenticated HTTP providers.
208
+ */
209
+ apiKey: string;
210
+ }
211
+ /**
212
+ * Resolve `{ baseUrl, apiKey }` for a given provider config and wire protocol
213
+ * without requiring an agent context.
214
+ *
215
+ * Intended for infrastructure-layer consumers (e.g., adapter-voice-bridge, cloud
216
+ * STT/TTS providers) that need to make HTTP calls to cloud providers but are not
217
+ * part of an agent turn.
218
+ *
219
+ * Delegates the common lookup chain (config → definition → endpoint → credentials)
220
+ * to {@link resolveProviderResolution} and applies strict validation on the result:
221
+ * both `baseUrl` and `apiKey` must be present or an error is thrown.
222
+ *
223
+ * Resolution order for the endpoint URL:
224
+ * 1. `ProviderConfig.endpointOverrides[protocol]` (user-customised URL)
225
+ * 2. `ProviderDefinition.endpoints[protocol]` (default from provider package)
226
+ *
227
+ * Credentials are resolved from the config's stored credential refs via the bus.
228
+ * @param bus - Makaio bus instance used to query storage and resolve credential refs
229
+ * @param providerConfigId - UUID of the ProviderConfig entity to resolve
230
+ * @param protocol - Wire protocol to select the correct endpoint URL
231
+ * @returns Resolved `{ baseUrl, apiKey }` for the provider
232
+ * @throws Error when the ProviderConfig or its ProviderDefinition is not found, or
233
+ * when `baseUrl` or `apiKey` cannot be resolved from any source
234
+ */
235
+ declare function resolveProviderEndpoint(bus: IMakaioBus, providerConfigId: string, protocol: ProtocolId): Promise<ProviderEndpoint>;
236
+ //#endregion
237
+ //#region adapters/core/src/config/resolve-provider-resolution.d.ts
238
+ /**
239
+ * Fully resolved provider data returned by {@link resolveProviderResolution}.
240
+ *
241
+ * Callers use this to build protocol-specific outputs (e.g. adapter config,
242
+ * HTTP endpoint) without duplicating the lookup chain.
243
+ */
244
+ interface ProviderResolution {
245
+ /** Bus-safe provider config read model from the adapter subsystem. */
246
+ config: ProviderConfigFileRecord;
247
+ /** The ProviderDefinition record referenced by the config. */
248
+ definition: ProviderRecord;
249
+ /**
250
+ * Resolved base URL for the requested protocol.
251
+ * `null` when neither the config override nor the definition declares an
252
+ * endpoint for the requested protocol.
253
+ */
254
+ baseUrl: string | null;
255
+ /**
256
+ * Plaintext credentials resolved from the config's credential refs.
257
+ * Empty object when no credentials are configured or none resolve.
258
+ */
259
+ credentials: Record<string, string>;
260
+ }
261
+ /**
262
+ * Resolve a ProviderConfig to its full runtime data: config record,
263
+ * definition record, endpoint URL, and plaintext credentials.
264
+ *
265
+ * Encapsulates the common lookup chain shared by the adapter config factory
266
+ * and the provider endpoint resolver:
267
+ * 1. `AdapterSubsystemSubjects.getProviderConfig` for the canonical read model
268
+ * 2. `AdapterSubsystemSubjects.buildProviderContext` for runtime credential refs and endpoint overrides
269
+ * 3. `ProviderStorageSubjects.get` for provider-definition metadata
270
+ * 4. `context.endpointOverrides?.[protocol] ?? definition.endpoints?.[protocol]`
271
+ * 5. Opens a DirectChannel via `CredentialSubjects.getChannelToken` and
272
+ * resolves each credential ref; the channel is closed after use.
273
+ *
274
+ * Callers keep only their differing post-resolution logic (e.g., strict
275
+ * `baseUrl` / `apiKey` validation for HTTP bridges vs. nullable `baseUrl`
276
+ * for adapter factories that allow env-var fallbacks).
277
+ * @param bus - Bus instance for storage and credential requests
278
+ * @param providerConfigId - UUID of the ProviderConfig to resolve
279
+ * @param protocol - Wire protocol used to select the correct endpoint URL
280
+ * @returns Fully resolved provider data
281
+ * @throws Error when the ProviderConfig or its ProviderDefinition is not found
282
+ */
283
+ declare function resolveProviderResolution(bus: IMakaioBus, providerConfigId: string, protocol: ProtocolId): Promise<ProviderResolution>;
284
+ //#endregion
285
+ //#region adapters/core/src/config/resolve-connector-credentials.d.ts
286
+ /** Minimal bus surface needed to resolve credentials against the shared runtime context. */
287
+ interface CredentialBusContextProvider {
288
+ getContext(): MakaioBusContext;
289
+ }
290
+ /**
291
+ * Resolve credential references to plaintext values at the connector layer.
292
+ *
293
+ * Opens an encrypted DirectChannel, resolves all refs in parallel, and
294
+ * closes the channel after use. Connectors call this during initialization
295
+ * or credential rotation — plaintext never leaves the connector.
296
+ *
297
+ * Returns an empty object immediately when `credentialRefs` is empty,
298
+ * avoiding an unnecessary channel round-trip. Partial failures are
299
+ * tolerated: refs that fail to resolve are omitted and logged. Callers
300
+ * must still validate any required credential fields before using the
301
+ * returned record to build env or client config.
302
+ * @param bus - Bus instance with context access for channel token retrieval
303
+ * @param credentialRefs - Credential refs keyed by field name
304
+ * @returns Plaintext credential values keyed by field name
305
+ */
306
+ declare function resolveConnectorCredentials(bus: CredentialBusContextProvider, credentialRefs: Record<string, CredentialRef>): Promise<Record<string, string>>;
307
+ //#endregion
308
+ //#region adapters/core/src/config/build-credential-env.d.ts
309
+ /**
310
+ * Build environment variables from resolved credentials.
311
+ *
312
+ * Maps plaintext credential values to their environment variable names
313
+ * using the provider definition's `credentialEnvVars` mapping. Subprocess
314
+ * adapters use this to set the correct env vars before spawning.
315
+ * @example
316
+ * ```typescript
317
+ * // { apiKey: 'sk-...' } + { apiKey: 'ANTHROPIC_API_KEY' }
318
+ * // → { ANTHROPIC_API_KEY: 'sk-...' }
319
+ * ```
320
+ * @param credentials - Resolved plaintext credentials keyed by field name
321
+ * @param credentialEnvVars - Mapping from credential field names to env var names
322
+ * @returns Environment variables ready for process.env / subprocess spawn
323
+ */
324
+ declare function buildCredentialEnv(credentials: Record<string, string>, credentialEnvVars: Record<string, string> | undefined): Record<string, string>;
325
+ //#endregion
326
+ //#region adapters/core/src/config/resolve-session-environment.d.ts
327
+ /** Minimal bus surface needed for session environment resolution. */
328
+ interface SessionEnvironmentBus {
329
+ getContext(): MakaioBusContext;
330
+ }
331
+ /**
332
+ * Unresolved provider context fields needed for session environment resolution.
333
+ *
334
+ * Mirrors the relevant subset of {@link ProviderContext} from `@makaio/contracts`
335
+ * so callers can pass the full provider context object without importing it here.
336
+ */
337
+ interface ProviderContextShape {
338
+ /** Provider config UUID carried by full provider contexts. */
339
+ providerConfigId?: string;
340
+ /** Provider definition ID carried by full provider contexts. */
341
+ definitionId?: string;
342
+ /** Credential references keyed by field name. */
343
+ credentialRefs: Record<string, CredentialRef>;
344
+ /** Maps credential field names to env var names for subprocess adapters. */
345
+ credentialEnvVars?: Record<string, string>;
346
+ /** Ambient provider credential env vars to strip before explicit credential injection. */
347
+ ambientCredentialEnvVars?: readonly string[];
348
+ }
349
+ /**
350
+ * Input options for {@link resolveSessionEnvironment}.
351
+ */
352
+ interface SessionEnvironmentOptions {
353
+ /** Bus instance used to resolve credential references. */
354
+ bus: SessionEnvironmentBus;
355
+ /**
356
+ * Unresolved provider context carrying credential refs and env-var mapping.
357
+ * When `undefined`, the credential steps are skipped and `credentials` / `credEnv`
358
+ * are returned as empty objects.
359
+ */
360
+ providerContext: ProviderContextShape | undefined;
361
+ /**
362
+ * Stable client identifier passed to `resolveClientBinary`
363
+ * (e.g. `'claude-code'`, `'qwen'`, `'github-copilot'`).
364
+ */
365
+ clientId: string;
366
+ /**
367
+ * Base environment variables that are merged into `spawnEnv` before credential
368
+ * env and binary env are applied. Typically the connector's own `this.env`.
369
+ */
370
+ baseEnv?: Record<string, string>;
371
+ }
372
+ /**
373
+ * Fully resolved session environment returned by {@link resolveSessionEnvironment}.
374
+ *
375
+ * All three resolution steps are returned individually so callers that need
376
+ * non-standard composition (e.g. optional binary env) can do so without
377
+ * repeating the resolution calls.
378
+ */
379
+ interface SessionEnvironmentResult {
380
+ /**
381
+ * Plaintext credentials keyed by field name.
382
+ * Empty when `providerContext` is `undefined` or carries no credential refs.
383
+ */
384
+ credentials: Record<string, string>;
385
+ /**
386
+ * Environment variables derived from `credentials` via the provider's
387
+ * `credentialEnvVars` mapping.
388
+ * Empty when `providerContext` is `undefined` or carries no `credentialEnvVars`.
389
+ */
390
+ credEnv: Record<string, string>;
391
+ /**
392
+ * Execution context for the resolved client binary, or `undefined` when
393
+ * no `client.resolveBinary` handler is registered (framework-only boot).
394
+ */
395
+ resolvedBinary: ClientExecutionContext | undefined;
396
+ /**
397
+ * Merged spawn environment for the common case:
398
+ * `{ ...cleanBaseEnv, ...credEnv, ...(resolvedBinary?.env ?? {}) }`.
399
+ *
400
+ * Ambient provider credential env vars are stripped from base env first.
401
+ * Credential env then takes precedence so that explicitly resolved secrets are
402
+ * restored. Binary env finally wins over credential env to enforce config
403
+ * isolation.
404
+ */
405
+ spawnEnv: Record<string, string>;
406
+ }
407
+ /**
408
+ * Resolve credentials, build credential environment variables, and locate the
409
+ * client binary — the three-step pattern shared by subprocess connectors.
410
+ *
411
+ * Encapsulates:
412
+ * 1. `resolveConnectorCredentials(bus, credentialRefs)` — opens an encrypted
413
+ * DirectChannel, resolves each ref, and closes the channel.
414
+ * 2. `buildCredentialEnv(credentials, credentialEnvVars)` — maps credential
415
+ * values to subprocess env var names.
416
+ * 3. `resolveClientBinary(clientId)` — dispatches `client.resolveBinary` on the
417
+ * static bus; returns `undefined` in framework-only boot.
418
+ *
419
+ * The returned {@link SessionEnvironmentResult} includes every intermediate
420
+ * value so callers with non-standard composition strategies (e.g. connectors
421
+ * that treat binary env as optional or pass credentials through a different
422
+ * channel) can compose the final env themselves.
423
+ * @param options - Session environment resolution options
424
+ * @returns Resolved credentials, credential env, binary execution context, and
425
+ * merged spawn environment
426
+ */
427
+ declare function resolveSessionEnvironment(options: SessionEnvironmentOptions): Promise<SessionEnvironmentResult>;
428
+ //#endregion
429
+ export { type AIModel, AIModelSchema, type AdapterConfigFactoryInput, type AdapterDefaults, type BaseAdapterConfig, BaseAdapterConfigSchema, type BaseProviderConfig, BaseProviderConfigSchema, type ConfigFactoryResult, type CreateAdapterConfigFactoryOptions, type FactoryGuaranteedFields, type ProviderConfig, ProviderConfigSchema, type ProviderDefaults, ProviderDefaultsSchema, type ProviderEndpoint, type ProviderResolution, type ResolveCredentialRefDeps, type SessionEnvironmentOptions, type SessionEnvironmentResult, buildCredentialEnv, createAdapterConfigFactory, getDefinitionOrThrow, resolveConnectorCredentials, resolveCredentialRef, resolveProviderEndpoint, resolveProviderResolution, resolveSessionEnvironment };
@@ -0,0 +1 @@
1
+ import{t as e}from"../../cleanEnvForAdapter-KkYzQa1f.mjs";import{z as t}from"zod";import n from"node:fs/promises";import{createBusInstance as r,openChannel as i}from"@makaio/framework/bus";import{AIModelSchema as a,CredentialSubjects as o}from"@makaio/framework/contracts";import{BaseAdapterConfigSchema as s,ProviderConfigSchema as c,ProviderDefaultsSchema as l}from"@makaio/framework/contracts/config";import{ProviderStorageSubjects as u}from"@makaio/framework/services/settings/storage";import{resolveTimeouts as d}from"@makaio/framework/utils";import{AdapterSubsystemSubjects as f}from"@makaio/framework/services/adapter-subsystem";import{resolveClientBinary as p}from"@makaio/framework/clients";async function m(e,t={}){if(e.startsWith(`env:`)){let n=e.slice(4);if(!n)throw Error(`Credential reference is missing environment variable name`);return(t.readEnv??(e=>process.env[e]))(n)||null}if(e.startsWith(`file:`)){let r=e.slice(5);if(!r)throw Error(`Credential reference is missing file path`);return(await(t.readFile??(async e=>await n.readFile(e,`utf-8`)))(r)).trim()||null}if(e.startsWith(`keychain:`)){let[n,...r]=e.slice(9).split(`:`);if(!n||r.length===0)throw Error(`Credential reference is missing keychain service or account`);if(!t.resolveKeychain)throw Error(`Keychain credential resolution is not configured`);return t.resolveKeychain(n,r.join(`:`))}return e||null}function h(e,t){let n=e.find(e=>e.id===t);if(!n)throw Error(`Provider definition not found: '${t}'`);if(!g(n))throw Error(`Provider definition '${t}' is missing a defaultModel`);return n}function g(e){return typeof e.defaultModel==`string`&&e.defaultModel.length>0}const _=t.record(t.string(),t.unknown());function v(e){return{getDefaults:()=>e().adapterDefaults,getConfig:async t=>{let{adapterName:n,adapterDefaults:r,adapterDefinition:i,protocol:a}=e(),{providerContext:o}=t,s=o.endpointOverrides?.[a]??null,c=d([{layer:`adapter`,source:n,config:i.defaultTimeouts},{layer:`runtime`,source:`config.ts`,config:t.runtimeTimeouts}]),l={...r.providerConfig,...t.providerConfig,baseUrl:s??t.providerConfig?.baseUrl??r.providerConfig?.baseUrl},u=t.model??r.model;if(!u)throw Error(`No model resolved for adapter "${n}" (agentId: ${t.agentId}). Provide a model explicitly or configure adapterDefaults.model.`);return{...r,...t,adapterName:t.adapterName,model:u,cwd:t.cwd??r.cwd??process.cwd(),timeouts:c,providerConfig:l}}}}async function y(e,t){let n=Object.entries(t);if(n.length===0)return{};let a={},s=e.getContext(),{token:c}=await r({context:s}).request(o.getChannelToken,{}),l=await i(s,`credentials`,{token:c,transports:[]});try{let e=await Promise.allSettled(n.map(([,e])=>l.request(o.resolve,{ref:e})));for(let t=0;t<n.length;t++){let[r,i]=n[t],o=e[t];if(o.status===`fulfilled`)if(o.value.value!==null)a[r]=o.value.value;else if(o.value.error){let e=JSON.stringify(i);console.warn(`[resolveConnectorCredentials] Failed to resolve field '${r}' (ref ${e}):`,o.value.error)}else{let e=JSON.stringify(i);console.info(`[resolveConnectorCredentials] Credential unavailable for field '${r}' (ref ${e}); omitting it from the resolved connector credentials.`)}else{let e=JSON.stringify(i);console.warn(`[resolveConnectorCredentials] Failed to resolve field '${r}' (ref ${e}):`,o.reason)}}}finally{l.close()}return a}async function b(e,t,n){let{config:r}=await e.request(f.getProviderConfig,{id:t});if(!r)throw Error(`ProviderConfig '${t}' not found`);let{context:i}=await e.request(f.buildProviderContext,{providerConfigId:t});if(!i)throw Error(`ProviderConfig '${t}' not found`);if(i.definitionId!==r.definitionId)throw Error(`ProviderConfig '${t}' changed during resolution; retry`);let{provider:a}=await e.request(u.get,{id:i.definitionId});if(!a)throw Error(`ProviderDefinition '${r.definitionId}' not found for config '${t}'`);return{config:r,definition:a,baseUrl:i.endpointOverrides?.[n]??a.endpoints?.[n]??null,credentials:await y(e,i.credentialRefs)}}async function x(e,t,n){let{baseUrl:r,credentials:i}=await b(e,t,n);if(!r)throw Error(`Could not resolve baseUrl for ProviderConfig '${t}' with protocol '${n}'. Ensure the provider definition or config override declares an endpoint for this protocol.`);let a=i.apiKey;if(!a)throw Error(`Could not resolve apiKey for ProviderConfig '${t}'. Store credentials via settings before using this provider.`);return{baseUrl:r,apiKey:a}}function S(e,t){if(!t)return{};let n={};for(let[r,i]of Object.entries(t)){let t=e[r];t!==void 0&&(n[i]=t)}return n}async function C(t){let{bus:n,providerContext:r,clientId:i,baseEnv:a={}}=t,o=await y(n,r?.credentialRefs??{}),s=S(o,r?.credentialEnvVars),c=await p(i);return{credentials:o,credEnv:s,resolvedBinary:c,spawnEnv:{...e(a,{omitEnvVars:r?.ambientCredentialEnvVars}),...s,...c?.env??{}}}}export{a as AIModelSchema,s as BaseAdapterConfigSchema,_ as BaseProviderConfigSchema,c as ProviderConfigSchema,l as ProviderDefaultsSchema,S as buildCredentialEnv,v as createAdapterConfigFactory,h as getDefinitionOrThrow,y as resolveConnectorCredentials,m as resolveCredentialRef,x as resolveProviderEndpoint,b as resolveProviderResolution,C as resolveSessionEnvironment};