@vellumai/assistant 0.4.55 → 0.4.57

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 (1673) hide show
  1. package/ARCHITECTURE.md +161 -167
  2. package/Dockerfile +9 -9
  3. package/README.md +12 -12
  4. package/bun.lock +145 -112
  5. package/docs/architecture/integrations.md +24 -24
  6. package/docs/architecture/memory.md +53 -54
  7. package/docs/architecture/security.md +2 -2
  8. package/docs/credential-execution-service.md +404 -0
  9. package/knip.json +5 -1
  10. package/node_modules/@vellumai/ces-contracts/bun.lock +29 -0
  11. package/node_modules/@vellumai/ces-contracts/package.json +24 -0
  12. package/node_modules/@vellumai/ces-contracts/src/__tests__/contracts.test.ts +293 -0
  13. package/node_modules/@vellumai/ces-contracts/src/__tests__/grants.test.ts +686 -0
  14. package/node_modules/@vellumai/ces-contracts/src/error.ts +26 -0
  15. package/node_modules/@vellumai/ces-contracts/src/grants.ts +184 -0
  16. package/node_modules/@vellumai/ces-contracts/src/handles.ts +213 -0
  17. package/node_modules/@vellumai/ces-contracts/src/index.ts +147 -0
  18. package/node_modules/@vellumai/ces-contracts/src/rendering.ts +135 -0
  19. package/node_modules/@vellumai/ces-contracts/src/rpc.ts +511 -0
  20. package/node_modules/@vellumai/ces-contracts/tsconfig.json +20 -0
  21. package/node_modules/@vellumai/credential-storage/bun.lock +24 -0
  22. package/node_modules/@vellumai/credential-storage/package.json +17 -0
  23. package/node_modules/@vellumai/credential-storage/src/__tests__/package-boundary.test.ts +151 -0
  24. package/node_modules/@vellumai/credential-storage/src/index.ts +213 -0
  25. package/node_modules/@vellumai/credential-storage/src/oauth-runtime.ts +340 -0
  26. package/node_modules/@vellumai/credential-storage/src/static-credentials.ts +365 -0
  27. package/node_modules/@vellumai/credential-storage/tsconfig.json +20 -0
  28. package/node_modules/@vellumai/egress-proxy/bun.lock +24 -0
  29. package/node_modules/@vellumai/egress-proxy/package.json +17 -0
  30. package/node_modules/@vellumai/egress-proxy/src/__tests__/package-boundary.test.ts +131 -0
  31. package/node_modules/@vellumai/egress-proxy/src/index.ts +54 -0
  32. package/node_modules/@vellumai/egress-proxy/src/session-core.ts +466 -0
  33. package/node_modules/@vellumai/egress-proxy/src/types.ts +227 -0
  34. package/node_modules/@vellumai/egress-proxy/tsconfig.json +20 -0
  35. package/node_modules/zod/LICENSE +21 -0
  36. package/node_modules/zod/README.md +208 -0
  37. package/node_modules/zod/index.cjs +33 -0
  38. package/node_modules/zod/index.d.cts +4 -0
  39. package/node_modules/zod/index.d.ts +4 -0
  40. package/node_modules/zod/index.js +4 -0
  41. package/node_modules/zod/locales/index.cjs +17 -0
  42. package/node_modules/zod/locales/index.d.cts +1 -0
  43. package/node_modules/zod/locales/index.d.ts +1 -0
  44. package/node_modules/zod/locales/index.js +1 -0
  45. package/node_modules/zod/locales/package.json +6 -0
  46. package/node_modules/zod/mini/index.cjs +32 -0
  47. package/node_modules/zod/mini/index.d.cts +3 -0
  48. package/node_modules/zod/mini/index.d.ts +3 -0
  49. package/node_modules/zod/mini/index.js +3 -0
  50. package/node_modules/zod/mini/package.json +6 -0
  51. package/node_modules/zod/package.json +135 -0
  52. package/node_modules/zod/src/index.ts +4 -0
  53. package/node_modules/zod/src/locales/index.ts +1 -0
  54. package/node_modules/zod/src/mini/index.ts +3 -0
  55. package/node_modules/zod/src/v3/ZodError.ts +330 -0
  56. package/node_modules/zod/src/v3/benchmarks/datetime.ts +58 -0
  57. package/node_modules/zod/src/v3/benchmarks/discriminatedUnion.ts +80 -0
  58. package/node_modules/zod/src/v3/benchmarks/index.ts +59 -0
  59. package/node_modules/zod/src/v3/benchmarks/ipv4.ts +57 -0
  60. package/node_modules/zod/src/v3/benchmarks/object.ts +69 -0
  61. package/node_modules/zod/src/v3/benchmarks/primitives.ts +162 -0
  62. package/node_modules/zod/src/v3/benchmarks/realworld.ts +63 -0
  63. package/node_modules/zod/src/v3/benchmarks/string.ts +55 -0
  64. package/node_modules/zod/src/v3/benchmarks/union.ts +80 -0
  65. package/node_modules/zod/src/v3/errors.ts +13 -0
  66. package/node_modules/zod/src/v3/external.ts +6 -0
  67. package/node_modules/zod/src/v3/helpers/enumUtil.ts +17 -0
  68. package/node_modules/zod/src/v3/helpers/errorUtil.ts +8 -0
  69. package/node_modules/zod/src/v3/helpers/parseUtil.ts +176 -0
  70. package/node_modules/zod/src/v3/helpers/partialUtil.ts +34 -0
  71. package/node_modules/zod/src/v3/helpers/typeAliases.ts +2 -0
  72. package/node_modules/zod/src/v3/helpers/util.ts +224 -0
  73. package/node_modules/zod/src/v3/index.ts +4 -0
  74. package/node_modules/zod/src/v3/locales/en.ts +124 -0
  75. package/node_modules/zod/src/v3/standard-schema.ts +113 -0
  76. package/node_modules/zod/src/v3/tests/Mocker.ts +54 -0
  77. package/node_modules/zod/src/v3/tests/all-errors.test.ts +157 -0
  78. package/node_modules/zod/src/v3/tests/anyunknown.test.ts +28 -0
  79. package/node_modules/zod/src/v3/tests/array.test.ts +71 -0
  80. package/node_modules/zod/src/v3/tests/async-parsing.test.ts +388 -0
  81. package/node_modules/zod/src/v3/tests/async-refinements.test.ts +46 -0
  82. package/node_modules/zod/src/v3/tests/base.test.ts +29 -0
  83. package/node_modules/zod/src/v3/tests/bigint.test.ts +55 -0
  84. package/node_modules/zod/src/v3/tests/branded.test.ts +53 -0
  85. package/node_modules/zod/src/v3/tests/catch.test.ts +220 -0
  86. package/node_modules/zod/src/v3/tests/coerce.test.ts +133 -0
  87. package/node_modules/zod/src/v3/tests/complex.test.ts +70 -0
  88. package/node_modules/zod/src/v3/tests/custom.test.ts +31 -0
  89. package/node_modules/zod/src/v3/tests/date.test.ts +32 -0
  90. package/node_modules/zod/src/v3/tests/deepmasking.test.ts +186 -0
  91. package/node_modules/zod/src/v3/tests/default.test.ts +112 -0
  92. package/node_modules/zod/src/v3/tests/description.test.ts +33 -0
  93. package/node_modules/zod/src/v3/tests/discriminated-unions.test.ts +315 -0
  94. package/node_modules/zod/src/v3/tests/enum.test.ts +80 -0
  95. package/node_modules/zod/src/v3/tests/error.test.ts +551 -0
  96. package/node_modules/zod/src/v3/tests/firstparty.test.ts +87 -0
  97. package/node_modules/zod/src/v3/tests/firstpartyschematypes.test.ts +21 -0
  98. package/node_modules/zod/src/v3/tests/function.test.ts +261 -0
  99. package/node_modules/zod/src/v3/tests/generics.test.ts +48 -0
  100. package/node_modules/zod/src/v3/tests/instanceof.test.ts +37 -0
  101. package/node_modules/zod/src/v3/tests/intersection.test.ts +110 -0
  102. package/node_modules/zod/src/v3/tests/language-server.source.ts +76 -0
  103. package/node_modules/zod/src/v3/tests/language-server.test.ts +207 -0
  104. package/node_modules/zod/src/v3/tests/literal.test.ts +36 -0
  105. package/node_modules/zod/src/v3/tests/map.test.ts +110 -0
  106. package/node_modules/zod/src/v3/tests/masking.test.ts +4 -0
  107. package/node_modules/zod/src/v3/tests/mocker.test.ts +19 -0
  108. package/node_modules/zod/src/v3/tests/nan.test.ts +24 -0
  109. package/node_modules/zod/src/v3/tests/nativeEnum.test.ts +87 -0
  110. package/node_modules/zod/src/v3/tests/nullable.test.ts +42 -0
  111. package/node_modules/zod/src/v3/tests/number.test.ts +176 -0
  112. package/node_modules/zod/src/v3/tests/object-augmentation.test.ts +29 -0
  113. package/node_modules/zod/src/v3/tests/object-in-es5-env.test.ts +29 -0
  114. package/node_modules/zod/src/v3/tests/object.test.ts +434 -0
  115. package/node_modules/zod/src/v3/tests/optional.test.ts +42 -0
  116. package/node_modules/zod/src/v3/tests/parseUtil.test.ts +23 -0
  117. package/node_modules/zod/src/v3/tests/parser.test.ts +41 -0
  118. package/node_modules/zod/src/v3/tests/partials.test.ts +243 -0
  119. package/node_modules/zod/src/v3/tests/pickomit.test.ts +111 -0
  120. package/node_modules/zod/src/v3/tests/pipeline.test.ts +29 -0
  121. package/node_modules/zod/src/v3/tests/preprocess.test.ts +186 -0
  122. package/node_modules/zod/src/v3/tests/primitive.test.ts +440 -0
  123. package/node_modules/zod/src/v3/tests/promise.test.ts +90 -0
  124. package/node_modules/zod/src/v3/tests/readonly.test.ts +194 -0
  125. package/node_modules/zod/src/v3/tests/record.test.ts +171 -0
  126. package/node_modules/zod/src/v3/tests/recursive.test.ts +197 -0
  127. package/node_modules/zod/src/v3/tests/refine.test.ts +313 -0
  128. package/node_modules/zod/src/v3/tests/safeparse.test.ts +27 -0
  129. package/node_modules/zod/src/v3/tests/set.test.ts +142 -0
  130. package/node_modules/zod/src/v3/tests/standard-schema.test.ts +83 -0
  131. package/node_modules/zod/src/v3/tests/string.test.ts +916 -0
  132. package/node_modules/zod/src/v3/tests/transformer.test.ts +233 -0
  133. package/node_modules/zod/src/v3/tests/tuple.test.ts +90 -0
  134. package/node_modules/zod/src/v3/tests/unions.test.ts +57 -0
  135. package/node_modules/zod/src/v3/tests/validations.test.ts +133 -0
  136. package/node_modules/zod/src/v3/tests/void.test.ts +15 -0
  137. package/node_modules/zod/src/v3/types.ts +5138 -0
  138. package/node_modules/zod/src/v4/classic/checks.ts +32 -0
  139. package/node_modules/zod/src/v4/classic/coerce.ts +27 -0
  140. package/node_modules/zod/src/v4/classic/compat.ts +70 -0
  141. package/node_modules/zod/src/v4/classic/errors.ts +82 -0
  142. package/node_modules/zod/src/v4/classic/external.ts +51 -0
  143. package/node_modules/zod/src/v4/classic/from-json-schema.ts +643 -0
  144. package/node_modules/zod/src/v4/classic/index.ts +5 -0
  145. package/node_modules/zod/src/v4/classic/iso.ts +90 -0
  146. package/node_modules/zod/src/v4/classic/parse.ts +82 -0
  147. package/node_modules/zod/src/v4/classic/schemas.ts +2409 -0
  148. package/node_modules/zod/src/v4/classic/tests/anyunknown.test.ts +26 -0
  149. package/node_modules/zod/src/v4/classic/tests/apply.test.ts +59 -0
  150. package/node_modules/zod/src/v4/classic/tests/array.test.ts +264 -0
  151. package/node_modules/zod/src/v4/classic/tests/assignability.test.ts +210 -0
  152. package/node_modules/zod/src/v4/classic/tests/async-parsing.test.ts +381 -0
  153. package/node_modules/zod/src/v4/classic/tests/async-refinements.test.ts +68 -0
  154. package/node_modules/zod/src/v4/classic/tests/base.test.ts +7 -0
  155. package/node_modules/zod/src/v4/classic/tests/bigint.test.ts +54 -0
  156. package/node_modules/zod/src/v4/classic/tests/brand.test.ts +106 -0
  157. package/node_modules/zod/src/v4/classic/tests/catch.test.ts +276 -0
  158. package/node_modules/zod/src/v4/classic/tests/coalesce.test.ts +20 -0
  159. package/node_modules/zod/src/v4/classic/tests/codec-examples.test.ts +573 -0
  160. package/node_modules/zod/src/v4/classic/tests/codec.test.ts +562 -0
  161. package/node_modules/zod/src/v4/classic/tests/coerce.test.ts +160 -0
  162. package/node_modules/zod/src/v4/classic/tests/continuability.test.ts +374 -0
  163. package/node_modules/zod/src/v4/classic/tests/custom.test.ts +40 -0
  164. package/node_modules/zod/src/v4/classic/tests/date.test.ts +62 -0
  165. package/node_modules/zod/src/v4/classic/tests/datetime.test.ts +302 -0
  166. package/node_modules/zod/src/v4/classic/tests/default.test.ts +365 -0
  167. package/node_modules/zod/src/v4/classic/tests/describe-meta-checks.test.ts +27 -0
  168. package/node_modules/zod/src/v4/classic/tests/description.test.ts +32 -0
  169. package/node_modules/zod/src/v4/classic/tests/discriminated-unions.test.ts +661 -0
  170. package/node_modules/zod/src/v4/classic/tests/enum.test.ts +285 -0
  171. package/node_modules/zod/src/v4/classic/tests/error-utils.test.ts +595 -0
  172. package/node_modules/zod/src/v4/classic/tests/error.test.ts +711 -0
  173. package/node_modules/zod/src/v4/classic/tests/file.test.ts +96 -0
  174. package/node_modules/zod/src/v4/classic/tests/firstparty.test.ts +179 -0
  175. package/node_modules/zod/src/v4/classic/tests/fix-json-issue.test.ts +26 -0
  176. package/node_modules/zod/src/v4/classic/tests/from-json-schema.test.ts +734 -0
  177. package/node_modules/zod/src/v4/classic/tests/function.test.ts +360 -0
  178. package/node_modules/zod/src/v4/classic/tests/generics.test.ts +72 -0
  179. package/node_modules/zod/src/v4/classic/tests/hash.test.ts +68 -0
  180. package/node_modules/zod/src/v4/classic/tests/index.test.ts +939 -0
  181. package/node_modules/zod/src/v4/classic/tests/instanceof.test.ts +60 -0
  182. package/node_modules/zod/src/v4/classic/tests/intersection.test.ts +198 -0
  183. package/node_modules/zod/src/v4/classic/tests/json.test.ts +109 -0
  184. package/node_modules/zod/src/v4/classic/tests/lazy.test.ts +227 -0
  185. package/node_modules/zod/src/v4/classic/tests/literal.test.ts +117 -0
  186. package/node_modules/zod/src/v4/classic/tests/map.test.ts +330 -0
  187. package/node_modules/zod/src/v4/classic/tests/nan.test.ts +21 -0
  188. package/node_modules/zod/src/v4/classic/tests/nested-refine.test.ts +168 -0
  189. package/node_modules/zod/src/v4/classic/tests/nonoptional.test.ts +101 -0
  190. package/node_modules/zod/src/v4/classic/tests/nullable.test.ts +22 -0
  191. package/node_modules/zod/src/v4/classic/tests/number.test.ts +270 -0
  192. package/node_modules/zod/src/v4/classic/tests/object.test.ts +640 -0
  193. package/node_modules/zod/src/v4/classic/tests/optional.test.ts +223 -0
  194. package/node_modules/zod/src/v4/classic/tests/partial.test.ts +427 -0
  195. package/node_modules/zod/src/v4/classic/tests/pickomit.test.ts +211 -0
  196. package/node_modules/zod/src/v4/classic/tests/pipe.test.ts +101 -0
  197. package/node_modules/zod/src/v4/classic/tests/prefault.test.ts +74 -0
  198. package/node_modules/zod/src/v4/classic/tests/preprocess.test.ts +282 -0
  199. package/node_modules/zod/src/v4/classic/tests/primitive.test.ts +175 -0
  200. package/node_modules/zod/src/v4/classic/tests/promise.test.ts +81 -0
  201. package/node_modules/zod/src/v4/classic/tests/prototypes.test.ts +23 -0
  202. package/node_modules/zod/src/v4/classic/tests/readonly.test.ts +252 -0
  203. package/node_modules/zod/src/v4/classic/tests/record.test.ts +632 -0
  204. package/node_modules/zod/src/v4/classic/tests/recursive-types.test.ts +582 -0
  205. package/node_modules/zod/src/v4/classic/tests/refine.test.ts +570 -0
  206. package/node_modules/zod/src/v4/classic/tests/registries.test.ts +243 -0
  207. package/node_modules/zod/src/v4/classic/tests/set.test.ts +181 -0
  208. package/node_modules/zod/src/v4/classic/tests/standard-schema.test.ts +134 -0
  209. package/node_modules/zod/src/v4/classic/tests/string-formats.test.ts +125 -0
  210. package/node_modules/zod/src/v4/classic/tests/string.test.ts +1175 -0
  211. package/node_modules/zod/src/v4/classic/tests/stringbool.test.ts +106 -0
  212. package/node_modules/zod/src/v4/classic/tests/template-literal.test.ts +771 -0
  213. package/node_modules/zod/src/v4/classic/tests/to-json-schema-methods.test.ts +438 -0
  214. package/node_modules/zod/src/v4/classic/tests/to-json-schema.test.ts +2990 -0
  215. package/node_modules/zod/src/v4/classic/tests/transform.test.ts +361 -0
  216. package/node_modules/zod/src/v4/classic/tests/tuple.test.ts +183 -0
  217. package/node_modules/zod/src/v4/classic/tests/union.test.ts +219 -0
  218. package/node_modules/zod/src/v4/classic/tests/url.test.ts +13 -0
  219. package/node_modules/zod/src/v4/classic/tests/validations.test.ts +283 -0
  220. package/node_modules/zod/src/v4/classic/tests/void.test.ts +12 -0
  221. package/node_modules/zod/src/v4/core/api.ts +1798 -0
  222. package/node_modules/zod/src/v4/core/checks.ts +1293 -0
  223. package/node_modules/zod/src/v4/core/config.ts +15 -0
  224. package/node_modules/zod/src/v4/core/core.ts +138 -0
  225. package/node_modules/zod/src/v4/core/doc.ts +44 -0
  226. package/node_modules/zod/src/v4/core/errors.ts +448 -0
  227. package/node_modules/zod/src/v4/core/index.ts +16 -0
  228. package/node_modules/zod/src/v4/core/json-schema-generator.ts +126 -0
  229. package/node_modules/zod/src/v4/core/json-schema-processors.ts +667 -0
  230. package/node_modules/zod/src/v4/core/json-schema.ts +147 -0
  231. package/node_modules/zod/src/v4/core/parse.ts +195 -0
  232. package/node_modules/zod/src/v4/core/regexes.ts +183 -0
  233. package/node_modules/zod/src/v4/core/registries.ts +105 -0
  234. package/node_modules/zod/src/v4/core/schemas.ts +4538 -0
  235. package/node_modules/zod/src/v4/core/standard-schema.ts +159 -0
  236. package/node_modules/zod/src/v4/core/tests/extend.test.ts +59 -0
  237. package/node_modules/zod/src/v4/core/tests/index.test.ts +46 -0
  238. package/node_modules/zod/src/v4/core/tests/locales/be.test.ts +124 -0
  239. package/node_modules/zod/src/v4/core/tests/locales/en.test.ts +22 -0
  240. package/node_modules/zod/src/v4/core/tests/locales/es.test.ts +181 -0
  241. package/node_modules/zod/src/v4/core/tests/locales/he.test.ts +379 -0
  242. package/node_modules/zod/src/v4/core/tests/locales/nl.test.ts +46 -0
  243. package/node_modules/zod/src/v4/core/tests/locales/ru.test.ts +128 -0
  244. package/node_modules/zod/src/v4/core/tests/locales/tr.test.ts +69 -0
  245. package/node_modules/zod/src/v4/core/tests/locales/uz.test.ts +83 -0
  246. package/node_modules/zod/src/v4/core/tests/record-constructor.test.ts +67 -0
  247. package/node_modules/zod/src/v4/core/tests/recursive-tuples.test.ts +45 -0
  248. package/node_modules/zod/src/v4/core/to-json-schema.ts +613 -0
  249. package/node_modules/zod/src/v4/core/util.ts +966 -0
  250. package/node_modules/zod/src/v4/core/versions.ts +5 -0
  251. package/node_modules/zod/src/v4/core/zsf.ts +323 -0
  252. package/node_modules/zod/src/v4/index.ts +4 -0
  253. package/node_modules/zod/src/v4/locales/ar.ts +115 -0
  254. package/node_modules/zod/src/v4/locales/az.ts +111 -0
  255. package/node_modules/zod/src/v4/locales/be.ts +176 -0
  256. package/node_modules/zod/src/v4/locales/bg.ts +128 -0
  257. package/node_modules/zod/src/v4/locales/ca.ts +116 -0
  258. package/node_modules/zod/src/v4/locales/cs.ts +118 -0
  259. package/node_modules/zod/src/v4/locales/da.ts +123 -0
  260. package/node_modules/zod/src/v4/locales/de.ts +116 -0
  261. package/node_modules/zod/src/v4/locales/en.ts +119 -0
  262. package/node_modules/zod/src/v4/locales/eo.ts +118 -0
  263. package/node_modules/zod/src/v4/locales/es.ts +141 -0
  264. package/node_modules/zod/src/v4/locales/fa.ts +126 -0
  265. package/node_modules/zod/src/v4/locales/fi.ts +121 -0
  266. package/node_modules/zod/src/v4/locales/fr-CA.ts +116 -0
  267. package/node_modules/zod/src/v4/locales/fr.ts +116 -0
  268. package/node_modules/zod/src/v4/locales/he.ts +246 -0
  269. package/node_modules/zod/src/v4/locales/hu.ts +117 -0
  270. package/node_modules/zod/src/v4/locales/hy.ts +164 -0
  271. package/node_modules/zod/src/v4/locales/id.ts +115 -0
  272. package/node_modules/zod/src/v4/locales/index.ts +49 -0
  273. package/node_modules/zod/src/v4/locales/is.ts +119 -0
  274. package/node_modules/zod/src/v4/locales/it.ts +116 -0
  275. package/node_modules/zod/src/v4/locales/ja.ts +114 -0
  276. package/node_modules/zod/src/v4/locales/ka.ts +123 -0
  277. package/node_modules/zod/src/v4/locales/kh.ts +7 -0
  278. package/node_modules/zod/src/v4/locales/km.ts +119 -0
  279. package/node_modules/zod/src/v4/locales/ko.ts +121 -0
  280. package/node_modules/zod/src/v4/locales/lt.ts +239 -0
  281. package/node_modules/zod/src/v4/locales/mk.ts +118 -0
  282. package/node_modules/zod/src/v4/locales/ms.ts +115 -0
  283. package/node_modules/zod/src/v4/locales/nl.ts +121 -0
  284. package/node_modules/zod/src/v4/locales/no.ts +116 -0
  285. package/node_modules/zod/src/v4/locales/ota.ts +117 -0
  286. package/node_modules/zod/src/v4/locales/pl.ts +118 -0
  287. package/node_modules/zod/src/v4/locales/ps.ts +126 -0
  288. package/node_modules/zod/src/v4/locales/pt.ts +116 -0
  289. package/node_modules/zod/src/v4/locales/ru.ts +176 -0
  290. package/node_modules/zod/src/v4/locales/sl.ts +118 -0
  291. package/node_modules/zod/src/v4/locales/sv.ts +119 -0
  292. package/node_modules/zod/src/v4/locales/ta.ts +118 -0
  293. package/node_modules/zod/src/v4/locales/th.ts +119 -0
  294. package/node_modules/zod/src/v4/locales/tr.ts +111 -0
  295. package/node_modules/zod/src/v4/locales/ua.ts +7 -0
  296. package/node_modules/zod/src/v4/locales/uk.ts +117 -0
  297. package/node_modules/zod/src/v4/locales/ur.ts +119 -0
  298. package/node_modules/zod/src/v4/locales/uz.ts +116 -0
  299. package/node_modules/zod/src/v4/locales/vi.ts +117 -0
  300. package/node_modules/zod/src/v4/locales/yo.ts +124 -0
  301. package/node_modules/zod/src/v4/locales/zh-CN.ts +116 -0
  302. package/node_modules/zod/src/v4/locales/zh-TW.ts +115 -0
  303. package/node_modules/zod/src/v4/mini/checks.ts +32 -0
  304. package/node_modules/zod/src/v4/mini/coerce.ts +27 -0
  305. package/node_modules/zod/src/v4/mini/external.ts +40 -0
  306. package/node_modules/zod/src/v4/mini/index.ts +3 -0
  307. package/node_modules/zod/src/v4/mini/iso.ts +66 -0
  308. package/node_modules/zod/src/v4/mini/parse.ts +14 -0
  309. package/node_modules/zod/src/v4/mini/schemas.ts +1916 -0
  310. package/node_modules/zod/src/v4/mini/tests/apply.test.ts +24 -0
  311. package/node_modules/zod/src/v4/mini/tests/assignability.test.ts +129 -0
  312. package/node_modules/zod/src/v4/mini/tests/brand.test.ts +94 -0
  313. package/node_modules/zod/src/v4/mini/tests/checks.test.ts +144 -0
  314. package/node_modules/zod/src/v4/mini/tests/codec.test.ts +529 -0
  315. package/node_modules/zod/src/v4/mini/tests/computed.test.ts +36 -0
  316. package/node_modules/zod/src/v4/mini/tests/error.test.ts +22 -0
  317. package/node_modules/zod/src/v4/mini/tests/functions.test.ts +5 -0
  318. package/node_modules/zod/src/v4/mini/tests/index.test.ts +963 -0
  319. package/node_modules/zod/src/v4/mini/tests/number.test.ts +95 -0
  320. package/node_modules/zod/src/v4/mini/tests/object.test.ts +227 -0
  321. package/node_modules/zod/src/v4/mini/tests/prototypes.test.ts +43 -0
  322. package/node_modules/zod/src/v4/mini/tests/recursive-types.test.ts +275 -0
  323. package/node_modules/zod/src/v4/mini/tests/standard-schema.test.ts +50 -0
  324. package/node_modules/zod/src/v4/mini/tests/string.test.ts +347 -0
  325. package/node_modules/zod/src/v4-mini/index.ts +3 -0
  326. package/node_modules/zod/v3/ZodError.cjs +138 -0
  327. package/node_modules/zod/v3/ZodError.d.cts +164 -0
  328. package/node_modules/zod/v3/ZodError.d.ts +164 -0
  329. package/node_modules/zod/v3/ZodError.js +133 -0
  330. package/node_modules/zod/v3/errors.cjs +17 -0
  331. package/node_modules/zod/v3/errors.d.cts +5 -0
  332. package/node_modules/zod/v3/errors.d.ts +5 -0
  333. package/node_modules/zod/v3/errors.js +9 -0
  334. package/node_modules/zod/v3/external.cjs +22 -0
  335. package/node_modules/zod/v3/external.d.cts +6 -0
  336. package/node_modules/zod/v3/external.d.ts +6 -0
  337. package/node_modules/zod/v3/external.js +6 -0
  338. package/node_modules/zod/v3/helpers/enumUtil.cjs +2 -0
  339. package/node_modules/zod/v3/helpers/enumUtil.d.cts +8 -0
  340. package/node_modules/zod/v3/helpers/enumUtil.d.ts +8 -0
  341. package/node_modules/zod/v3/helpers/enumUtil.js +1 -0
  342. package/node_modules/zod/v3/helpers/errorUtil.cjs +9 -0
  343. package/node_modules/zod/v3/helpers/errorUtil.d.cts +9 -0
  344. package/node_modules/zod/v3/helpers/errorUtil.d.ts +9 -0
  345. package/node_modules/zod/v3/helpers/errorUtil.js +6 -0
  346. package/node_modules/zod/v3/helpers/parseUtil.cjs +124 -0
  347. package/node_modules/zod/v3/helpers/parseUtil.d.cts +78 -0
  348. package/node_modules/zod/v3/helpers/parseUtil.d.ts +78 -0
  349. package/node_modules/zod/v3/helpers/parseUtil.js +109 -0
  350. package/node_modules/zod/v3/helpers/partialUtil.cjs +2 -0
  351. package/node_modules/zod/v3/helpers/partialUtil.d.cts +8 -0
  352. package/node_modules/zod/v3/helpers/partialUtil.d.ts +8 -0
  353. package/node_modules/zod/v3/helpers/partialUtil.js +1 -0
  354. package/node_modules/zod/v3/helpers/typeAliases.cjs +2 -0
  355. package/node_modules/zod/v3/helpers/typeAliases.d.cts +2 -0
  356. package/node_modules/zod/v3/helpers/typeAliases.d.ts +2 -0
  357. package/node_modules/zod/v3/helpers/typeAliases.js +1 -0
  358. package/node_modules/zod/v3/helpers/util.cjs +137 -0
  359. package/node_modules/zod/v3/helpers/util.d.cts +85 -0
  360. package/node_modules/zod/v3/helpers/util.d.ts +85 -0
  361. package/node_modules/zod/v3/helpers/util.js +133 -0
  362. package/node_modules/zod/v3/index.cjs +33 -0
  363. package/node_modules/zod/v3/index.d.cts +4 -0
  364. package/node_modules/zod/v3/index.d.ts +4 -0
  365. package/node_modules/zod/v3/index.js +4 -0
  366. package/node_modules/zod/v3/locales/en.cjs +112 -0
  367. package/node_modules/zod/v3/locales/en.d.cts +3 -0
  368. package/node_modules/zod/v3/locales/en.d.ts +3 -0
  369. package/node_modules/zod/v3/locales/en.js +109 -0
  370. package/node_modules/zod/v3/package.json +6 -0
  371. package/node_modules/zod/v3/standard-schema.cjs +2 -0
  372. package/node_modules/zod/v3/standard-schema.d.cts +102 -0
  373. package/node_modules/zod/v3/standard-schema.d.ts +102 -0
  374. package/node_modules/zod/v3/standard-schema.js +1 -0
  375. package/node_modules/zod/v3/types.cjs +3777 -0
  376. package/node_modules/zod/v3/types.d.cts +1034 -0
  377. package/node_modules/zod/v3/types.d.ts +1034 -0
  378. package/node_modules/zod/v3/types.js +3695 -0
  379. package/node_modules/zod/v4/classic/checks.cjs +33 -0
  380. package/node_modules/zod/v4/classic/checks.d.cts +1 -0
  381. package/node_modules/zod/v4/classic/checks.d.ts +1 -0
  382. package/node_modules/zod/v4/classic/checks.js +1 -0
  383. package/node_modules/zod/v4/classic/coerce.cjs +47 -0
  384. package/node_modules/zod/v4/classic/coerce.d.cts +17 -0
  385. package/node_modules/zod/v4/classic/coerce.d.ts +17 -0
  386. package/node_modules/zod/v4/classic/coerce.js +17 -0
  387. package/node_modules/zod/v4/classic/compat.cjs +61 -0
  388. package/node_modules/zod/v4/classic/compat.d.cts +50 -0
  389. package/node_modules/zod/v4/classic/compat.d.ts +50 -0
  390. package/node_modules/zod/v4/classic/compat.js +31 -0
  391. package/node_modules/zod/v4/classic/errors.cjs +74 -0
  392. package/node_modules/zod/v4/classic/errors.d.cts +30 -0
  393. package/node_modules/zod/v4/classic/errors.d.ts +30 -0
  394. package/node_modules/zod/v4/classic/errors.js +48 -0
  395. package/node_modules/zod/v4/classic/external.cjs +73 -0
  396. package/node_modules/zod/v4/classic/external.d.cts +15 -0
  397. package/node_modules/zod/v4/classic/external.d.ts +15 -0
  398. package/node_modules/zod/v4/classic/external.js +20 -0
  399. package/node_modules/zod/v4/classic/from-json-schema.cjs +610 -0
  400. package/node_modules/zod/v4/classic/from-json-schema.d.cts +12 -0
  401. package/node_modules/zod/v4/classic/from-json-schema.d.ts +12 -0
  402. package/node_modules/zod/v4/classic/from-json-schema.js +584 -0
  403. package/node_modules/zod/v4/classic/index.cjs +33 -0
  404. package/node_modules/zod/v4/classic/index.d.cts +4 -0
  405. package/node_modules/zod/v4/classic/index.d.ts +4 -0
  406. package/node_modules/zod/v4/classic/index.js +4 -0
  407. package/node_modules/zod/v4/classic/iso.cjs +60 -0
  408. package/node_modules/zod/v4/classic/iso.d.cts +22 -0
  409. package/node_modules/zod/v4/classic/iso.d.ts +22 -0
  410. package/node_modules/zod/v4/classic/iso.js +30 -0
  411. package/node_modules/zod/v4/classic/package.json +6 -0
  412. package/node_modules/zod/v4/classic/parse.cjs +41 -0
  413. package/node_modules/zod/v4/classic/parse.d.cts +31 -0
  414. package/node_modules/zod/v4/classic/parse.d.ts +31 -0
  415. package/node_modules/zod/v4/classic/parse.js +15 -0
  416. package/node_modules/zod/v4/classic/schemas.cjs +1272 -0
  417. package/node_modules/zod/v4/classic/schemas.d.cts +739 -0
  418. package/node_modules/zod/v4/classic/schemas.d.ts +739 -0
  419. package/node_modules/zod/v4/classic/schemas.js +1157 -0
  420. package/node_modules/zod/v4/core/api.cjs +1222 -0
  421. package/node_modules/zod/v4/core/api.d.cts +304 -0
  422. package/node_modules/zod/v4/core/api.d.ts +304 -0
  423. package/node_modules/zod/v4/core/api.js +1082 -0
  424. package/node_modules/zod/v4/core/checks.cjs +601 -0
  425. package/node_modules/zod/v4/core/checks.d.cts +278 -0
  426. package/node_modules/zod/v4/core/checks.d.ts +278 -0
  427. package/node_modules/zod/v4/core/checks.js +575 -0
  428. package/node_modules/zod/v4/core/core.cjs +83 -0
  429. package/node_modules/zod/v4/core/core.d.cts +70 -0
  430. package/node_modules/zod/v4/core/core.d.ts +70 -0
  431. package/node_modules/zod/v4/core/core.js +76 -0
  432. package/node_modules/zod/v4/core/doc.cjs +39 -0
  433. package/node_modules/zod/v4/core/doc.d.cts +14 -0
  434. package/node_modules/zod/v4/core/doc.d.ts +14 -0
  435. package/node_modules/zod/v4/core/doc.js +35 -0
  436. package/node_modules/zod/v4/core/errors.cjs +213 -0
  437. package/node_modules/zod/v4/core/errors.d.cts +220 -0
  438. package/node_modules/zod/v4/core/errors.d.ts +220 -0
  439. package/node_modules/zod/v4/core/errors.js +182 -0
  440. package/node_modules/zod/v4/core/index.cjs +47 -0
  441. package/node_modules/zod/v4/core/index.d.cts +16 -0
  442. package/node_modules/zod/v4/core/index.d.ts +16 -0
  443. package/node_modules/zod/v4/core/index.js +16 -0
  444. package/node_modules/zod/v4/core/json-schema-generator.cjs +99 -0
  445. package/node_modules/zod/v4/core/json-schema-generator.d.cts +65 -0
  446. package/node_modules/zod/v4/core/json-schema-generator.d.ts +65 -0
  447. package/node_modules/zod/v4/core/json-schema-generator.js +95 -0
  448. package/node_modules/zod/v4/core/json-schema-processors.cjs +648 -0
  449. package/node_modules/zod/v4/core/json-schema-processors.d.cts +49 -0
  450. package/node_modules/zod/v4/core/json-schema-processors.d.ts +49 -0
  451. package/node_modules/zod/v4/core/json-schema-processors.js +605 -0
  452. package/node_modules/zod/v4/core/json-schema.cjs +2 -0
  453. package/node_modules/zod/v4/core/json-schema.d.cts +88 -0
  454. package/node_modules/zod/v4/core/json-schema.d.ts +88 -0
  455. package/node_modules/zod/v4/core/json-schema.js +1 -0
  456. package/node_modules/zod/v4/core/package.json +6 -0
  457. package/node_modules/zod/v4/core/parse.cjs +131 -0
  458. package/node_modules/zod/v4/core/parse.d.cts +49 -0
  459. package/node_modules/zod/v4/core/parse.d.ts +49 -0
  460. package/node_modules/zod/v4/core/parse.js +93 -0
  461. package/node_modules/zod/v4/core/regexes.cjs +166 -0
  462. package/node_modules/zod/v4/core/regexes.d.cts +79 -0
  463. package/node_modules/zod/v4/core/regexes.d.ts +79 -0
  464. package/node_modules/zod/v4/core/regexes.js +133 -0
  465. package/node_modules/zod/v4/core/registries.cjs +56 -0
  466. package/node_modules/zod/v4/core/registries.d.cts +35 -0
  467. package/node_modules/zod/v4/core/registries.d.ts +35 -0
  468. package/node_modules/zod/v4/core/registries.js +51 -0
  469. package/node_modules/zod/v4/core/schemas.cjs +2124 -0
  470. package/node_modules/zod/v4/core/schemas.d.cts +1146 -0
  471. package/node_modules/zod/v4/core/schemas.d.ts +1146 -0
  472. package/node_modules/zod/v4/core/schemas.js +2093 -0
  473. package/node_modules/zod/v4/core/standard-schema.cjs +2 -0
  474. package/node_modules/zod/v4/core/standard-schema.d.cts +126 -0
  475. package/node_modules/zod/v4/core/standard-schema.d.ts +126 -0
  476. package/node_modules/zod/v4/core/standard-schema.js +1 -0
  477. package/node_modules/zod/v4/core/to-json-schema.cjs +446 -0
  478. package/node_modules/zod/v4/core/to-json-schema.d.cts +114 -0
  479. package/node_modules/zod/v4/core/to-json-schema.d.ts +114 -0
  480. package/node_modules/zod/v4/core/to-json-schema.js +437 -0
  481. package/node_modules/zod/v4/core/util.cjs +710 -0
  482. package/node_modules/zod/v4/core/util.d.cts +199 -0
  483. package/node_modules/zod/v4/core/util.d.ts +199 -0
  484. package/node_modules/zod/v4/core/util.js +651 -0
  485. package/node_modules/zod/v4/core/versions.cjs +8 -0
  486. package/node_modules/zod/v4/core/versions.d.cts +5 -0
  487. package/node_modules/zod/v4/core/versions.d.ts +5 -0
  488. package/node_modules/zod/v4/core/versions.js +5 -0
  489. package/node_modules/zod/v4/index.cjs +22 -0
  490. package/node_modules/zod/v4/index.d.cts +3 -0
  491. package/node_modules/zod/v4/index.d.ts +3 -0
  492. package/node_modules/zod/v4/index.js +3 -0
  493. package/node_modules/zod/v4/locales/ar.cjs +133 -0
  494. package/node_modules/zod/v4/locales/ar.d.cts +5 -0
  495. package/node_modules/zod/v4/locales/ar.d.ts +4 -0
  496. package/node_modules/zod/v4/locales/ar.js +106 -0
  497. package/node_modules/zod/v4/locales/az.cjs +132 -0
  498. package/node_modules/zod/v4/locales/az.d.cts +5 -0
  499. package/node_modules/zod/v4/locales/az.d.ts +4 -0
  500. package/node_modules/zod/v4/locales/az.js +105 -0
  501. package/node_modules/zod/v4/locales/be.cjs +183 -0
  502. package/node_modules/zod/v4/locales/be.d.cts +5 -0
  503. package/node_modules/zod/v4/locales/be.d.ts +4 -0
  504. package/node_modules/zod/v4/locales/be.js +156 -0
  505. package/node_modules/zod/v4/locales/bg.cjs +147 -0
  506. package/node_modules/zod/v4/locales/bg.d.cts +5 -0
  507. package/node_modules/zod/v4/locales/bg.d.ts +4 -0
  508. package/node_modules/zod/v4/locales/bg.js +120 -0
  509. package/node_modules/zod/v4/locales/ca.cjs +134 -0
  510. package/node_modules/zod/v4/locales/ca.d.cts +5 -0
  511. package/node_modules/zod/v4/locales/ca.d.ts +4 -0
  512. package/node_modules/zod/v4/locales/ca.js +107 -0
  513. package/node_modules/zod/v4/locales/cs.cjs +138 -0
  514. package/node_modules/zod/v4/locales/cs.d.cts +5 -0
  515. package/node_modules/zod/v4/locales/cs.d.ts +4 -0
  516. package/node_modules/zod/v4/locales/cs.js +111 -0
  517. package/node_modules/zod/v4/locales/da.cjs +142 -0
  518. package/node_modules/zod/v4/locales/da.d.cts +5 -0
  519. package/node_modules/zod/v4/locales/da.d.ts +4 -0
  520. package/node_modules/zod/v4/locales/da.js +115 -0
  521. package/node_modules/zod/v4/locales/de.cjs +135 -0
  522. package/node_modules/zod/v4/locales/de.d.cts +5 -0
  523. package/node_modules/zod/v4/locales/de.d.ts +4 -0
  524. package/node_modules/zod/v4/locales/de.js +108 -0
  525. package/node_modules/zod/v4/locales/en.cjs +136 -0
  526. package/node_modules/zod/v4/locales/en.d.cts +5 -0
  527. package/node_modules/zod/v4/locales/en.d.ts +4 -0
  528. package/node_modules/zod/v4/locales/en.js +109 -0
  529. package/node_modules/zod/v4/locales/eo.cjs +136 -0
  530. package/node_modules/zod/v4/locales/eo.d.cts +5 -0
  531. package/node_modules/zod/v4/locales/eo.d.ts +4 -0
  532. package/node_modules/zod/v4/locales/eo.js +109 -0
  533. package/node_modules/zod/v4/locales/es.cjs +159 -0
  534. package/node_modules/zod/v4/locales/es.d.cts +5 -0
  535. package/node_modules/zod/v4/locales/es.d.ts +4 -0
  536. package/node_modules/zod/v4/locales/es.js +132 -0
  537. package/node_modules/zod/v4/locales/fa.cjs +141 -0
  538. package/node_modules/zod/v4/locales/fa.d.cts +5 -0
  539. package/node_modules/zod/v4/locales/fa.d.ts +4 -0
  540. package/node_modules/zod/v4/locales/fa.js +114 -0
  541. package/node_modules/zod/v4/locales/fi.cjs +139 -0
  542. package/node_modules/zod/v4/locales/fi.d.cts +5 -0
  543. package/node_modules/zod/v4/locales/fi.d.ts +4 -0
  544. package/node_modules/zod/v4/locales/fi.js +112 -0
  545. package/node_modules/zod/v4/locales/fr-CA.cjs +134 -0
  546. package/node_modules/zod/v4/locales/fr-CA.d.cts +5 -0
  547. package/node_modules/zod/v4/locales/fr-CA.d.ts +4 -0
  548. package/node_modules/zod/v4/locales/fr-CA.js +107 -0
  549. package/node_modules/zod/v4/locales/fr.cjs +135 -0
  550. package/node_modules/zod/v4/locales/fr.d.cts +5 -0
  551. package/node_modules/zod/v4/locales/fr.d.ts +4 -0
  552. package/node_modules/zod/v4/locales/fr.js +108 -0
  553. package/node_modules/zod/v4/locales/he.cjs +241 -0
  554. package/node_modules/zod/v4/locales/he.d.cts +5 -0
  555. package/node_modules/zod/v4/locales/he.d.ts +4 -0
  556. package/node_modules/zod/v4/locales/he.js +214 -0
  557. package/node_modules/zod/v4/locales/hu.cjs +135 -0
  558. package/node_modules/zod/v4/locales/hu.d.cts +5 -0
  559. package/node_modules/zod/v4/locales/hu.d.ts +4 -0
  560. package/node_modules/zod/v4/locales/hu.js +108 -0
  561. package/node_modules/zod/v4/locales/hy.cjs +174 -0
  562. package/node_modules/zod/v4/locales/hy.d.cts +5 -0
  563. package/node_modules/zod/v4/locales/hy.d.ts +4 -0
  564. package/node_modules/zod/v4/locales/hy.js +147 -0
  565. package/node_modules/zod/v4/locales/id.cjs +133 -0
  566. package/node_modules/zod/v4/locales/id.d.cts +5 -0
  567. package/node_modules/zod/v4/locales/id.d.ts +4 -0
  568. package/node_modules/zod/v4/locales/id.js +106 -0
  569. package/node_modules/zod/v4/locales/index.cjs +104 -0
  570. package/node_modules/zod/v4/locales/index.d.cts +49 -0
  571. package/node_modules/zod/v4/locales/index.d.ts +49 -0
  572. package/node_modules/zod/v4/locales/index.js +49 -0
  573. package/node_modules/zod/v4/locales/is.cjs +136 -0
  574. package/node_modules/zod/v4/locales/is.d.cts +5 -0
  575. package/node_modules/zod/v4/locales/is.d.ts +4 -0
  576. package/node_modules/zod/v4/locales/is.js +109 -0
  577. package/node_modules/zod/v4/locales/it.cjs +135 -0
  578. package/node_modules/zod/v4/locales/it.d.cts +5 -0
  579. package/node_modules/zod/v4/locales/it.d.ts +4 -0
  580. package/node_modules/zod/v4/locales/it.js +108 -0
  581. package/node_modules/zod/v4/locales/ja.cjs +134 -0
  582. package/node_modules/zod/v4/locales/ja.d.cts +5 -0
  583. package/node_modules/zod/v4/locales/ja.d.ts +4 -0
  584. package/node_modules/zod/v4/locales/ja.js +107 -0
  585. package/node_modules/zod/v4/locales/ka.cjs +139 -0
  586. package/node_modules/zod/v4/locales/ka.d.cts +5 -0
  587. package/node_modules/zod/v4/locales/ka.d.ts +4 -0
  588. package/node_modules/zod/v4/locales/ka.js +112 -0
  589. package/node_modules/zod/v4/locales/kh.cjs +12 -0
  590. package/node_modules/zod/v4/locales/kh.d.cts +5 -0
  591. package/node_modules/zod/v4/locales/kh.d.ts +5 -0
  592. package/node_modules/zod/v4/locales/kh.js +5 -0
  593. package/node_modules/zod/v4/locales/km.cjs +137 -0
  594. package/node_modules/zod/v4/locales/km.d.cts +5 -0
  595. package/node_modules/zod/v4/locales/km.d.ts +4 -0
  596. package/node_modules/zod/v4/locales/km.js +110 -0
  597. package/node_modules/zod/v4/locales/ko.cjs +138 -0
  598. package/node_modules/zod/v4/locales/ko.d.cts +5 -0
  599. package/node_modules/zod/v4/locales/ko.d.ts +4 -0
  600. package/node_modules/zod/v4/locales/ko.js +111 -0
  601. package/node_modules/zod/v4/locales/lt.cjs +230 -0
  602. package/node_modules/zod/v4/locales/lt.d.cts +5 -0
  603. package/node_modules/zod/v4/locales/lt.d.ts +4 -0
  604. package/node_modules/zod/v4/locales/lt.js +203 -0
  605. package/node_modules/zod/v4/locales/mk.cjs +136 -0
  606. package/node_modules/zod/v4/locales/mk.d.cts +5 -0
  607. package/node_modules/zod/v4/locales/mk.d.ts +4 -0
  608. package/node_modules/zod/v4/locales/mk.js +109 -0
  609. package/node_modules/zod/v4/locales/ms.cjs +134 -0
  610. package/node_modules/zod/v4/locales/ms.d.cts +5 -0
  611. package/node_modules/zod/v4/locales/ms.d.ts +4 -0
  612. package/node_modules/zod/v4/locales/ms.js +107 -0
  613. package/node_modules/zod/v4/locales/nl.cjs +137 -0
  614. package/node_modules/zod/v4/locales/nl.d.cts +5 -0
  615. package/node_modules/zod/v4/locales/nl.d.ts +4 -0
  616. package/node_modules/zod/v4/locales/nl.js +110 -0
  617. package/node_modules/zod/v4/locales/no.cjs +135 -0
  618. package/node_modules/zod/v4/locales/no.d.cts +5 -0
  619. package/node_modules/zod/v4/locales/no.d.ts +4 -0
  620. package/node_modules/zod/v4/locales/no.js +108 -0
  621. package/node_modules/zod/v4/locales/ota.cjs +136 -0
  622. package/node_modules/zod/v4/locales/ota.d.cts +5 -0
  623. package/node_modules/zod/v4/locales/ota.d.ts +4 -0
  624. package/node_modules/zod/v4/locales/ota.js +109 -0
  625. package/node_modules/zod/v4/locales/package.json +6 -0
  626. package/node_modules/zod/v4/locales/pl.cjs +136 -0
  627. package/node_modules/zod/v4/locales/pl.d.cts +5 -0
  628. package/node_modules/zod/v4/locales/pl.d.ts +4 -0
  629. package/node_modules/zod/v4/locales/pl.js +109 -0
  630. package/node_modules/zod/v4/locales/ps.cjs +141 -0
  631. package/node_modules/zod/v4/locales/ps.d.cts +5 -0
  632. package/node_modules/zod/v4/locales/ps.d.ts +4 -0
  633. package/node_modules/zod/v4/locales/ps.js +114 -0
  634. package/node_modules/zod/v4/locales/pt.cjs +135 -0
  635. package/node_modules/zod/v4/locales/pt.d.cts +5 -0
  636. package/node_modules/zod/v4/locales/pt.d.ts +4 -0
  637. package/node_modules/zod/v4/locales/pt.js +108 -0
  638. package/node_modules/zod/v4/locales/ru.cjs +183 -0
  639. package/node_modules/zod/v4/locales/ru.d.cts +5 -0
  640. package/node_modules/zod/v4/locales/ru.d.ts +4 -0
  641. package/node_modules/zod/v4/locales/ru.js +156 -0
  642. package/node_modules/zod/v4/locales/sl.cjs +136 -0
  643. package/node_modules/zod/v4/locales/sl.d.cts +5 -0
  644. package/node_modules/zod/v4/locales/sl.d.ts +4 -0
  645. package/node_modules/zod/v4/locales/sl.js +109 -0
  646. package/node_modules/zod/v4/locales/sv.cjs +137 -0
  647. package/node_modules/zod/v4/locales/sv.d.cts +5 -0
  648. package/node_modules/zod/v4/locales/sv.d.ts +4 -0
  649. package/node_modules/zod/v4/locales/sv.js +110 -0
  650. package/node_modules/zod/v4/locales/ta.cjs +137 -0
  651. package/node_modules/zod/v4/locales/ta.d.cts +5 -0
  652. package/node_modules/zod/v4/locales/ta.d.ts +4 -0
  653. package/node_modules/zod/v4/locales/ta.js +110 -0
  654. package/node_modules/zod/v4/locales/th.cjs +137 -0
  655. package/node_modules/zod/v4/locales/th.d.cts +5 -0
  656. package/node_modules/zod/v4/locales/th.d.ts +4 -0
  657. package/node_modules/zod/v4/locales/th.js +110 -0
  658. package/node_modules/zod/v4/locales/tr.cjs +132 -0
  659. package/node_modules/zod/v4/locales/tr.d.cts +5 -0
  660. package/node_modules/zod/v4/locales/tr.d.ts +4 -0
  661. package/node_modules/zod/v4/locales/tr.js +105 -0
  662. package/node_modules/zod/v4/locales/ua.cjs +12 -0
  663. package/node_modules/zod/v4/locales/ua.d.cts +5 -0
  664. package/node_modules/zod/v4/locales/ua.d.ts +5 -0
  665. package/node_modules/zod/v4/locales/ua.js +5 -0
  666. package/node_modules/zod/v4/locales/uk.cjs +135 -0
  667. package/node_modules/zod/v4/locales/uk.d.cts +5 -0
  668. package/node_modules/zod/v4/locales/uk.d.ts +4 -0
  669. package/node_modules/zod/v4/locales/uk.js +108 -0
  670. package/node_modules/zod/v4/locales/ur.cjs +137 -0
  671. package/node_modules/zod/v4/locales/ur.d.cts +5 -0
  672. package/node_modules/zod/v4/locales/ur.d.ts +4 -0
  673. package/node_modules/zod/v4/locales/ur.js +110 -0
  674. package/node_modules/zod/v4/locales/uz.cjs +136 -0
  675. package/node_modules/zod/v4/locales/uz.d.cts +5 -0
  676. package/node_modules/zod/v4/locales/uz.d.ts +4 -0
  677. package/node_modules/zod/v4/locales/uz.js +109 -0
  678. package/node_modules/zod/v4/locales/vi.cjs +135 -0
  679. package/node_modules/zod/v4/locales/vi.d.cts +5 -0
  680. package/node_modules/zod/v4/locales/vi.d.ts +4 -0
  681. package/node_modules/zod/v4/locales/vi.js +108 -0
  682. package/node_modules/zod/v4/locales/yo.cjs +134 -0
  683. package/node_modules/zod/v4/locales/yo.d.cts +5 -0
  684. package/node_modules/zod/v4/locales/yo.d.ts +4 -0
  685. package/node_modules/zod/v4/locales/yo.js +107 -0
  686. package/node_modules/zod/v4/locales/zh-CN.cjs +136 -0
  687. package/node_modules/zod/v4/locales/zh-CN.d.cts +5 -0
  688. package/node_modules/zod/v4/locales/zh-CN.d.ts +4 -0
  689. package/node_modules/zod/v4/locales/zh-CN.js +109 -0
  690. package/node_modules/zod/v4/locales/zh-TW.cjs +134 -0
  691. package/node_modules/zod/v4/locales/zh-TW.d.cts +5 -0
  692. package/node_modules/zod/v4/locales/zh-TW.d.ts +4 -0
  693. package/node_modules/zod/v4/locales/zh-TW.js +107 -0
  694. package/node_modules/zod/v4/mini/checks.cjs +34 -0
  695. package/node_modules/zod/v4/mini/checks.d.cts +1 -0
  696. package/node_modules/zod/v4/mini/checks.d.ts +1 -0
  697. package/node_modules/zod/v4/mini/checks.js +1 -0
  698. package/node_modules/zod/v4/mini/coerce.cjs +52 -0
  699. package/node_modules/zod/v4/mini/coerce.d.cts +7 -0
  700. package/node_modules/zod/v4/mini/coerce.d.ts +7 -0
  701. package/node_modules/zod/v4/mini/coerce.js +22 -0
  702. package/node_modules/zod/v4/mini/external.cjs +63 -0
  703. package/node_modules/zod/v4/mini/external.d.cts +12 -0
  704. package/node_modules/zod/v4/mini/external.d.ts +12 -0
  705. package/node_modules/zod/v4/mini/external.js +14 -0
  706. package/node_modules/zod/v4/mini/index.cjs +32 -0
  707. package/node_modules/zod/v4/mini/index.d.cts +3 -0
  708. package/node_modules/zod/v4/mini/index.d.ts +3 -0
  709. package/node_modules/zod/v4/mini/index.js +3 -0
  710. package/node_modules/zod/v4/mini/iso.cjs +64 -0
  711. package/node_modules/zod/v4/mini/iso.d.cts +22 -0
  712. package/node_modules/zod/v4/mini/iso.d.ts +22 -0
  713. package/node_modules/zod/v4/mini/iso.js +34 -0
  714. package/node_modules/zod/v4/mini/package.json +6 -0
  715. package/node_modules/zod/v4/mini/parse.cjs +16 -0
  716. package/node_modules/zod/v4/mini/parse.d.cts +1 -0
  717. package/node_modules/zod/v4/mini/parse.d.ts +1 -0
  718. package/node_modules/zod/v4/mini/parse.js +1 -0
  719. package/node_modules/zod/v4/mini/schemas.cjs +1046 -0
  720. package/node_modules/zod/v4/mini/schemas.d.cts +427 -0
  721. package/node_modules/zod/v4/mini/schemas.d.ts +427 -0
  722. package/node_modules/zod/v4/mini/schemas.js +925 -0
  723. package/node_modules/zod/v4/package.json +6 -0
  724. package/node_modules/zod/v4-mini/index.cjs +32 -0
  725. package/node_modules/zod/v4-mini/index.d.cts +3 -0
  726. package/node_modules/zod/v4-mini/index.d.ts +3 -0
  727. package/node_modules/zod/v4-mini/index.js +3 -0
  728. package/node_modules/zod/v4-mini/package.json +6 -0
  729. package/package.json +13 -2
  730. package/src/__tests__/acp-session.test.ts +292 -0
  731. package/src/__tests__/actor-token-service.test.ts +10 -10
  732. package/src/__tests__/always-loaded-tools-guard.test.ts +1 -1
  733. package/src/__tests__/anthropic-provider.test.ts +340 -46
  734. package/src/__tests__/app-builder-tool-scripts.test.ts +15 -2
  735. package/src/__tests__/approval-cascade.test.ts +123 -97
  736. package/src/__tests__/approval-primitive.test.ts +2 -2
  737. package/src/__tests__/approval-routes-http.test.ts +42 -28
  738. package/src/__tests__/asset-materialize-tool.test.ts +14 -21
  739. package/src/__tests__/asset-search-tool.test.ts +6 -13
  740. package/src/__tests__/assistant-attachments.test.ts +27 -0
  741. package/src/__tests__/assistant-event-hub.test.ts +14 -10
  742. package/src/__tests__/assistant-event.test.ts +9 -9
  743. package/src/__tests__/assistant-events-sse-hardening.test.ts +1 -1
  744. package/src/__tests__/assistant-feature-flag-guardrails.test.ts +6 -1
  745. package/src/__tests__/assistant-feature-flags-integration.test.ts +169 -40
  746. package/src/__tests__/attachments-store.test.ts +2 -2
  747. package/src/__tests__/avatar-e2e.test.ts +19 -7
  748. package/src/__tests__/avatar-generator.test.ts +4 -7
  749. package/src/__tests__/browser-fill-credential.test.ts +17 -18
  750. package/src/__tests__/browser-skill-endstate.test.ts +1 -2
  751. package/src/__tests__/btw-routes.test.ts +21 -9
  752. package/src/__tests__/call-controller.test.ts +229 -202
  753. package/src/__tests__/call-pointer-messages.test.ts +12 -10
  754. package/src/__tests__/call-routes-http.test.ts +4 -4
  755. package/src/__tests__/call-start-guardian-guard.test.ts +0 -1
  756. package/src/__tests__/callback-handoff-copy.test.ts +1 -1
  757. package/src/__tests__/cancel-resolves-conversation-key.test.ts +158 -0
  758. package/src/__tests__/canonical-guardian-store.test.ts +8 -10
  759. package/src/__tests__/channel-approval-routes.test.ts +5 -5
  760. package/src/__tests__/channel-approval.test.ts +1 -1
  761. package/src/__tests__/channel-approvals.test.ts +13 -13
  762. package/src/__tests__/channel-guardian.test.ts +3 -3
  763. package/src/__tests__/channel-invite-transport.test.ts +5 -1
  764. package/src/__tests__/channel-readiness-routes.test.ts +4 -1
  765. package/src/__tests__/channel-readiness-service.test.ts +0 -1
  766. package/src/__tests__/channel-reply-delivery.test.ts +1 -1
  767. package/src/__tests__/checker.test.ts +32 -33
  768. package/src/__tests__/chrome-cdp.test.ts +47 -18
  769. package/src/__tests__/claude-code-skill-regression.test.ts +67 -1
  770. package/src/__tests__/claude-code-tool-profiles.test.ts +1 -1
  771. package/src/__tests__/clipboard.test.ts +6 -6
  772. package/src/__tests__/commit-guarantee.test.ts +9 -9
  773. package/src/__tests__/commit-message-enrichment-service.test.ts +37 -6
  774. package/src/__tests__/computer-use-tools.test.ts +0 -1
  775. package/src/__tests__/config-loader-backfill.test.ts +6 -4
  776. package/src/__tests__/config-schema-cmd.test.ts +258 -0
  777. package/src/__tests__/config-schema.test.ts +45 -46
  778. package/src/__tests__/config-watcher.test.ts +25 -24
  779. package/src/__tests__/confirmation-request-guardian-bridge.test.ts +17 -15
  780. package/src/__tests__/contacts-tools.test.ts +0 -1
  781. package/src/__tests__/context-overflow-approval.test.ts +2 -2
  782. package/src/__tests__/{session-abort-tool-results.test.ts → conversation-abort-tool-results.test.ts} +26 -13
  783. package/src/__tests__/{session-agent-loop-overflow.test.ts → conversation-agent-loop-overflow.test.ts} +236 -61
  784. package/src/__tests__/{session-agent-loop.test.ts → conversation-agent-loop.test.ts} +88 -65
  785. package/src/__tests__/{session-approval-overrides.test.ts → conversation-approval-overrides.test.ts} +23 -23
  786. package/src/__tests__/conversation-attachments.test.ts +227 -0
  787. package/src/__tests__/conversation-attention-telegram.test.ts +2 -2
  788. package/src/__tests__/{session-confirmation-signals.test.ts → conversation-confirmation-signals.test.ts} +64 -54
  789. package/src/__tests__/{session-error.test.ts → conversation-error.test.ts} +98 -57
  790. package/src/__tests__/{session-evictor.test.ts → conversation-evictor.test.ts} +21 -17
  791. package/src/__tests__/{session-history-web-search.test.ts → conversation-history-web-search.test.ts} +34 -10
  792. package/src/__tests__/{session-init.benchmark.test.ts → conversation-init.benchmark.test.ts} +23 -24
  793. package/src/__tests__/{session-load-history-repair.test.ts → conversation-load-history-repair.test.ts} +39 -39
  794. package/src/__tests__/{session-media-retry.test.ts → conversation-media-retry.test.ts} +1 -1
  795. package/src/__tests__/{session-messaging-secret-redirect.test.ts → conversation-messaging-secret-redirect.test.ts} +1 -1
  796. package/src/__tests__/conversation-pairing.test.ts +47 -47
  797. package/src/__tests__/{session-pre-run-repair.test.ts → conversation-pre-run-repair.test.ts} +26 -13
  798. package/src/__tests__/{session-provider-retry-repair.test.ts → conversation-provider-retry-repair.test.ts} +61 -48
  799. package/src/__tests__/{session-queue.test.ts → conversation-queue.test.ts} +260 -230
  800. package/src/__tests__/conversation-routes-guardian-reply.test.ts +26 -26
  801. package/src/__tests__/conversation-routes-slash-commands.test.ts +34 -57
  802. package/src/__tests__/{session-runtime-assembly.test.ts → conversation-runtime-assembly.test.ts} +187 -175
  803. package/src/__tests__/{session-runtime-workspace.test.ts → conversation-runtime-workspace.test.ts} +1 -1
  804. package/src/__tests__/{thread-seed-composer.test.ts → conversation-seed-composer.test.ts} +51 -49
  805. package/src/__tests__/{session-skill-tools.test.ts → conversation-skill-tools.test.ts} +11 -13
  806. package/src/__tests__/{session-slash-queue.test.ts → conversation-slash-queue.test.ts} +57 -48
  807. package/src/__tests__/{session-slash-unknown.test.ts → conversation-slash-unknown.test.ts} +33 -77
  808. package/src/__tests__/conversation-starter-routes.test.ts +291 -0
  809. package/src/__tests__/conversation-store.test.ts +61 -55
  810. package/src/__tests__/{session-surfaces-deselection.test.ts → conversation-surfaces-deselection.test.ts} +5 -5
  811. package/src/__tests__/{session-surfaces-task-progress.test.ts → conversation-surfaces-task-progress.test.ts} +7 -7
  812. package/src/__tests__/{session-tool-setup-app-refresh.test.ts → conversation-tool-setup-app-refresh.test.ts} +5 -5
  813. package/src/__tests__/{session-tool-setup-memory-scope.test.ts → conversation-tool-setup-memory-scope.test.ts} +4 -4
  814. package/src/__tests__/{session-tool-setup-side-effect-flag.test.ts → conversation-tool-setup-side-effect-flag.test.ts} +4 -4
  815. package/src/__tests__/{session-tool-setup-tools-disabled.test.ts → conversation-tool-setup-tools-disabled.test.ts} +3 -3
  816. package/src/__tests__/{session-undo.test.ts → conversation-undo.test.ts} +1 -1
  817. package/src/__tests__/conversation-unread-route.test.ts +4 -0
  818. package/src/__tests__/{session-usage.test.ts → conversation-usage.test.ts} +1 -1
  819. package/src/__tests__/conversation-wipe.test.ts +438 -0
  820. package/src/__tests__/{session-workspace-cache-state.test.ts → conversation-workspace-cache-state.test.ts} +31 -39
  821. package/src/__tests__/{session-workspace-injection.test.ts → conversation-workspace-injection.test.ts} +60 -54
  822. package/src/__tests__/{session-workspace-tool-tracking.test.ts → conversation-workspace-tool-tracking.test.ts} +56 -50
  823. package/src/__tests__/credential-execution-admin-cli.test.ts +504 -0
  824. package/src/__tests__/credential-execution-api-key-propagation.test.ts +309 -0
  825. package/src/__tests__/credential-execution-approval-bridge.test.ts +535 -0
  826. package/src/__tests__/credential-execution-client.test.ts +380 -0
  827. package/src/__tests__/credential-execution-feature-gates.test.ts +169 -0
  828. package/src/__tests__/credential-execution-managed-contract.test.ts +526 -0
  829. package/src/__tests__/credential-execution-shell-lockdown.test.ts +149 -0
  830. package/src/__tests__/credential-execution-tools.test.ts +279 -0
  831. package/src/__tests__/credential-security-e2e.test.ts +20 -1
  832. package/src/__tests__/credential-security-invariants.test.ts +5 -8
  833. package/src/__tests__/credential-storage-oauth-compat.test.ts +606 -0
  834. package/src/__tests__/credential-storage-static-compat.test.ts +396 -0
  835. package/src/__tests__/credential-vault-unit.test.ts +227 -1
  836. package/src/__tests__/credential-vault.test.ts +0 -1
  837. package/src/__tests__/credentials-cli.test.ts +13 -22
  838. package/src/__tests__/cu-unified-flow.test.ts +8 -6
  839. package/src/__tests__/daemon-assistant-events.test.ts +15 -12
  840. package/src/__tests__/date-context.test.ts +59 -377
  841. package/src/__tests__/delete-managed-skill-tool.test.ts +0 -1
  842. package/src/__tests__/diagnostics-export.test.ts +30 -0
  843. package/src/__tests__/drop-capability-card-state-migration.test.ts +169 -0
  844. package/src/__tests__/dynamic-page-surface.test.ts +2 -2
  845. package/src/__tests__/dynamic-skill-workflow-prompt.test.ts +23 -43
  846. package/src/__tests__/emit-signal-routing-intent.test.ts +4 -4
  847. package/src/__tests__/encrypted-store.test.ts +237 -15
  848. package/src/__tests__/ephemeral-permissions.test.ts +4 -5
  849. package/src/__tests__/event-bus.test.ts +5 -9
  850. package/src/__tests__/file-edit-tool.test.ts +0 -1
  851. package/src/__tests__/file-read-tool.test.ts +0 -1
  852. package/src/__tests__/file-write-tool.test.ts +0 -1
  853. package/src/__tests__/fixtures/mock-signup-server.ts +2 -2
  854. package/src/__tests__/followup-tools.test.ts +25 -26
  855. package/src/__tests__/frontmatter.test.ts +12 -10
  856. package/src/__tests__/gateway-only-enforcement.test.ts +2 -2
  857. package/src/__tests__/gateway-only-guard.test.ts +1 -0
  858. package/src/__tests__/gemini-image-service.test.ts +4 -4
  859. package/src/__tests__/gemini-provider.test.ts +6 -9
  860. package/src/__tests__/guardian-action-late-reply.test.ts +1 -1
  861. package/src/__tests__/guardian-action-no-hardcoded-copy.test.ts +1 -1
  862. package/src/__tests__/guardian-binding-drift-heal.test.ts +128 -0
  863. package/src/__tests__/guardian-decision-primitive-canonical.test.ts +15 -15
  864. package/src/__tests__/guardian-dispatch.test.ts +9 -10
  865. package/src/__tests__/guardian-grant-minting.test.ts +5 -5
  866. package/src/__tests__/guardian-question-copy.test.ts +10 -8
  867. package/src/__tests__/guardian-routing-invariants.test.ts +61 -61
  868. package/src/__tests__/guardian-routing-state.test.ts +1 -1
  869. package/src/__tests__/guardian-verification-voice-binding.test.ts +1 -1
  870. package/src/__tests__/handlers-user-message-approval-consumption.test.ts +20 -16
  871. package/src/__tests__/headless-browser-interactions.test.ts +18 -17
  872. package/src/__tests__/headless-browser-navigate.test.ts +0 -1
  873. package/src/__tests__/headless-browser-read-tools.test.ts +5 -6
  874. package/src/__tests__/headless-browser-snapshot.test.ts +12 -9
  875. package/src/__tests__/heartbeat-service.test.ts +5 -4
  876. package/src/__tests__/hooks-ts-runner.test.ts +10 -4
  877. package/src/__tests__/host-bash-proxy.test.ts +50 -1
  878. package/src/__tests__/host-cu-proxy.test.ts +1 -1
  879. package/src/__tests__/host-file-edit-tool.test.ts +0 -1
  880. package/src/__tests__/host-file-proxy.test.ts +1 -1
  881. package/src/__tests__/host-file-read-tool.test.ts +0 -1
  882. package/src/__tests__/host-file-write-tool.test.ts +0 -1
  883. package/src/__tests__/host-shell-tool.test.ts +70 -11
  884. package/src/__tests__/http-user-message-parity.test.ts +32 -19
  885. package/src/__tests__/intent-routing.test.ts +68 -129
  886. package/src/__tests__/invite-redemption-service.test.ts +35 -0
  887. package/src/__tests__/invite-routes-http.test.ts +5 -0
  888. package/src/__tests__/keychain-broker-client.test.ts +150 -0
  889. package/src/__tests__/list-messages-attachments.test.ts +1 -1
  890. package/src/__tests__/log-export-workspace.test.ts +133 -60
  891. package/src/__tests__/managed-credential-catalog-cli.test.ts +349 -0
  892. package/src/__tests__/managed-proxy-context.test.ts +2 -5
  893. package/src/__tests__/managed-skill-lifecycle.test.ts +20 -8
  894. package/src/__tests__/managed-store.test.ts +0 -38
  895. package/src/__tests__/media-generate-image.test.ts +48 -14
  896. package/src/__tests__/media-reuse-story.e2e.test.ts +83 -71
  897. package/src/__tests__/media-visibility-policy.test.ts +10 -10
  898. package/src/__tests__/memory-context-benchmark.benchmark.test.ts +1 -1
  899. package/src/__tests__/memory-lifecycle-e2e.test.ts +24 -18
  900. package/src/__tests__/memory-query-builder.test.ts +2 -2
  901. package/src/__tests__/memory-recall-quality.test.ts +4 -3
  902. package/src/__tests__/memory-regressions.test.ts +153 -120
  903. package/src/__tests__/messaging-send-tool.test.ts +0 -2
  904. package/src/__tests__/migration-cross-version-compatibility.test.ts +32 -32
  905. package/src/__tests__/migration-export-http.test.ts +26 -27
  906. package/src/__tests__/migration-import-commit-http.test.ts +165 -37
  907. package/src/__tests__/migration-import-preflight-http.test.ts +81 -20
  908. package/src/__tests__/migration-validate-http.test.ts +16 -16
  909. package/src/__tests__/model-intents.test.ts +1 -1
  910. package/src/__tests__/no-domain-routing-in-prompt-guard.test.ts +51 -0
  911. package/src/__tests__/notification-broadcaster.test.ts +43 -41
  912. package/src/__tests__/{notification-thread-candidate-validation.test.ts → notification-conversation-candidate-validation.test.ts} +26 -24
  913. package/src/__tests__/{notification-thread-candidates.test.ts → notification-conversation-candidates.test.ts} +15 -15
  914. package/src/__tests__/notification-decision-fallback.test.ts +8 -8
  915. package/src/__tests__/notification-decision-identity.test.ts +208 -0
  916. package/src/__tests__/notification-decision-strategy.test.ts +41 -39
  917. package/src/__tests__/notification-deep-link.test.ts +19 -19
  918. package/src/__tests__/notification-guardian-path.test.ts +13 -11
  919. package/src/__tests__/notification-schedule-dedup.test.ts +7 -7
  920. package/src/__tests__/notification-telegram-adapter.test.ts +5 -5
  921. package/src/__tests__/oauth-store.test.ts +2 -8
  922. package/src/__tests__/oauth2-gateway-transport.test.ts +6 -1
  923. package/src/__tests__/onboarding-template-contract.test.ts +23 -59
  924. package/src/__tests__/permission-types.test.ts +1 -1
  925. package/src/__tests__/playbook-execution.test.ts +0 -1
  926. package/src/__tests__/playbook-tools.test.ts +0 -1
  927. package/src/__tests__/provider-commit-message-generator.test.ts +7 -6
  928. package/src/__tests__/provider-error-scenarios.test.ts +154 -0
  929. package/src/__tests__/provider-fail-open-selection.test.ts +22 -28
  930. package/src/__tests__/provider-managed-proxy-integration.test.ts +41 -63
  931. package/src/__tests__/provider-registry-ollama.test.ts +16 -2
  932. package/src/__tests__/proxy-approval-callback.test.ts +2 -2
  933. package/src/__tests__/qdrant-manager.test.ts +7 -7
  934. package/src/__tests__/ratelimit.test.ts +0 -74
  935. package/src/__tests__/recording-handler.test.ts +20 -21
  936. package/src/__tests__/relay-server.test.ts +8 -5
  937. package/src/__tests__/require-fresh-approval.test.ts +532 -0
  938. package/src/__tests__/resolve-trust-class.test.ts +2 -2
  939. package/src/__tests__/runtime-attachment-metadata.test.ts +1 -1
  940. package/src/__tests__/runtime-events-sse-parity.test.ts +22 -22
  941. package/src/__tests__/runtime-events-sse.test.ts +16 -8
  942. package/src/__tests__/scaffold-managed-skill-tool.test.ts +1 -4
  943. package/src/__tests__/schedule-tools.test.ts +0 -1
  944. package/src/__tests__/scheduler-recurrence.test.ts +46 -2
  945. package/src/__tests__/schema-transforms.test.ts +114 -54
  946. package/src/__tests__/scoped-approval-grants.test.ts +6 -6
  947. package/src/__tests__/scoped-grant-security-matrix.test.ts +1 -1
  948. package/src/__tests__/{script-proxy-session-manager.test.ts → script-proxy-conversation-manager.test.ts} +4 -1
  949. package/src/__tests__/secret-onetime-send.test.ts +20 -4
  950. package/src/__tests__/secret-response-routing.test.ts +1 -1
  951. package/src/__tests__/secret-routes-managed-proxy.test.ts +82 -2
  952. package/src/__tests__/secret-scanner-executor.test.ts +1 -4
  953. package/src/__tests__/send-endpoint-busy.test.ts +134 -62
  954. package/src/__tests__/send-notification-tool.test.ts +2 -4
  955. package/src/__tests__/sequence-store.test.ts +5 -5
  956. package/src/__tests__/shell-credential-ref.test.ts +1 -3
  957. package/src/__tests__/shell-tool-proxy-mode.test.ts +3 -5
  958. package/src/__tests__/skill-feature-flags-integration.test.ts +1 -2
  959. package/src/__tests__/skill-feature-flags.test.ts +7 -8
  960. package/src/__tests__/skill-include-graph.test.ts +1 -2
  961. package/src/__tests__/skill-load-feature-flag.test.ts +10 -11
  962. package/src/__tests__/skill-load-tool.test.ts +19 -15
  963. package/src/__tests__/skill-memory.test.ts +547 -0
  964. package/src/__tests__/skill-projection-feature-flag.test.ts +4 -6
  965. package/src/__tests__/skill-projection.benchmark.test.ts +3 -5
  966. package/src/__tests__/skill-script-runner-host.test.ts +3 -4
  967. package/src/__tests__/skill-script-runner-sandbox.test.ts +4 -6
  968. package/src/__tests__/skill-script-runner.test.ts +0 -1
  969. package/src/__tests__/skill-tool-factory.test.ts +0 -1
  970. package/src/__tests__/skills.test.ts +0 -37
  971. package/src/__tests__/slack-app-setup-skill-regression.test.ts +37 -0
  972. package/src/__tests__/slack-channel-config.test.ts +109 -94
  973. package/src/__tests__/slack-skill.test.ts +0 -4
  974. package/src/__tests__/starter-task-flow.test.ts +3 -3
  975. package/src/__tests__/subagent-manager-notify.test.ts +45 -40
  976. package/src/__tests__/subagent-tools.test.ts +78 -69
  977. package/src/__tests__/subagent-types.test.ts +3 -3
  978. package/src/__tests__/surface-mutex-cleanup.test.ts +1 -1
  979. package/src/__tests__/{swarm-session-integration.test.ts → swarm-conversation-integration.test.ts} +13 -1
  980. package/src/__tests__/swarm-recursion.test.ts +21 -9
  981. package/src/__tests__/swarm-tool.test.ts +14 -1
  982. package/src/__tests__/system-prompt.test.ts +50 -79
  983. package/src/__tests__/task-compiler.test.ts +1 -1
  984. package/src/__tests__/task-management-tools.test.ts +1 -2
  985. package/src/__tests__/telegram-config.test.ts +121 -0
  986. package/src/__tests__/terminal-sandbox.test.ts +6 -0
  987. package/src/__tests__/terminal-tools.test.ts +2 -2
  988. package/src/__tests__/token-estimator-accuracy.benchmark.test.ts +2 -2
  989. package/src/__tests__/tool-approval-handler.test.ts +2 -3
  990. package/src/__tests__/tool-audit-listener.test.ts +0 -6
  991. package/src/__tests__/tool-domain-event-publisher.test.ts +0 -11
  992. package/src/__tests__/tool-execution-abort-cleanup.test.ts +68 -16
  993. package/src/__tests__/tool-execution-pipeline.benchmark.test.ts +0 -1
  994. package/src/__tests__/tool-executor-lifecycle-events.test.ts +4 -7
  995. package/src/__tests__/tool-executor-shell-integration.test.ts +1 -2
  996. package/src/__tests__/tool-executor.test.ts +21 -21
  997. package/src/__tests__/tool-grant-request-escalation.test.ts +8 -9
  998. package/src/__tests__/tool-metrics-listener.test.ts +0 -9
  999. package/src/__tests__/tool-notification-listener.test.ts +0 -2
  1000. package/src/__tests__/tool-preview-lifecycle.test.ts +6 -6
  1001. package/src/__tests__/tool-profiling-listener.test.ts +0 -7
  1002. package/src/__tests__/tool-trace-listener.test.ts +0 -11
  1003. package/src/__tests__/trace-emitter.test.ts +9 -2
  1004. package/src/__tests__/trust-context-guards.test.ts +1 -1
  1005. package/src/__tests__/trust-store.test.ts +7 -8
  1006. package/src/__tests__/trusted-contact-approval-notifier.test.ts +1 -1
  1007. package/src/__tests__/trusted-contact-inline-approval-integration.test.ts +9 -10
  1008. package/src/__tests__/turn-commit.test.ts +3 -3
  1009. package/src/__tests__/twilio-routes.test.ts +1 -18
  1010. package/src/__tests__/ui-file-upload-surface.test.ts +2 -2
  1011. package/src/__tests__/user-reference.test.ts +82 -2
  1012. package/src/__tests__/vbundle-pax-and-symlink.test.ts +196 -0
  1013. package/src/__tests__/verification-control-plane-policy.test.ts +1 -2
  1014. package/src/__tests__/voice-scoped-grant-consumer.test.ts +4 -4
  1015. package/src/__tests__/voice-session-bridge.test.ts +31 -31
  1016. package/src/__tests__/workspace-git-service.test.ts +49 -2
  1017. package/src/__tests__/workspace-lifecycle.test.ts +6 -6
  1018. package/src/__tests__/workspace-migration-add-send-diagnostics.test.ts +59 -0
  1019. package/src/__tests__/workspace-migration-avatar-rename.test.ts +128 -0
  1020. package/src/__tests__/workspace-migration-extract-collect-usage-data.test.ts +179 -0
  1021. package/src/__tests__/workspace-migration-seed-device-id.test.ts +328 -0
  1022. package/src/__tests__/workspace-migrations-runner.test.ts +293 -0
  1023. package/src/acp/agent-process.ts +201 -0
  1024. package/src/acp/client-handler.ts +361 -0
  1025. package/src/acp/index.ts +44 -0
  1026. package/src/acp/session-manager.ts +348 -0
  1027. package/src/acp/types.ts +79 -0
  1028. package/src/approvals/AGENTS.md +2 -2
  1029. package/src/approvals/approval-primitive.ts +4 -4
  1030. package/src/approvals/guardian-decision-primitive.ts +7 -7
  1031. package/src/approvals/guardian-request-resolvers.ts +4 -4
  1032. package/src/avatar/ascii-renderer.ts +63 -0
  1033. package/src/avatar/character-components.ts +454 -0
  1034. package/src/avatar/png-renderer.ts +17 -0
  1035. package/src/avatar/resvg-lazy.ts +21 -0
  1036. package/src/avatar/svg-compositor.ts +90 -0
  1037. package/src/avatar/traits-png-sync.ts +133 -0
  1038. package/src/calls/call-controller.ts +8 -8
  1039. package/src/calls/call-conversation-messages.ts +1 -1
  1040. package/src/calls/call-domain.ts +4 -4
  1041. package/src/calls/call-pointer-message-composer.ts +2 -2
  1042. package/src/calls/call-pointer-messages.ts +10 -10
  1043. package/src/calls/guardian-action-sweep.ts +3 -3
  1044. package/src/calls/guardian-dispatch.ts +8 -8
  1045. package/src/calls/guardian-question-copy.ts +7 -7
  1046. package/src/calls/relay-access-wait.ts +2 -2
  1047. package/src/calls/relay-server.ts +4 -4
  1048. package/src/calls/twilio-rest.ts +0 -248
  1049. package/src/calls/twilio-routes.ts +1 -1
  1050. package/src/calls/voice-session-bridge.ts +59 -56
  1051. package/src/cli/AGENTS.md +6 -9
  1052. package/src/cli/__tests__/notifications.test.ts +5 -5
  1053. package/src/cli/commands/avatar.ts +343 -0
  1054. package/src/cli/commands/bash.ts +3 -3
  1055. package/src/cli/commands/channel-verification-sessions.ts +7 -4
  1056. package/src/cli/commands/completions.ts +4 -4
  1057. package/src/cli/commands/config.ts +52 -7
  1058. package/src/cli/commands/conversations.ts +386 -0
  1059. package/src/cli/commands/credential-execution.ts +345 -0
  1060. package/src/cli/commands/credentials.ts +108 -6
  1061. package/src/cli/commands/doctor.ts +9 -3
  1062. package/src/cli/commands/keys.ts +30 -0
  1063. package/src/cli/commands/mcp.ts +2 -2
  1064. package/src/cli/commands/memory.ts +8 -8
  1065. package/src/cli/commands/notifications.ts +4 -4
  1066. package/src/cli/commands/oauth/connections.ts +98 -17
  1067. package/src/cli/commands/oauth/providers.ts +45 -8
  1068. package/src/cli/commands/shotgun.ts +250 -0
  1069. package/src/cli/main-screen.tsx +3 -29
  1070. package/src/cli/program.ts +13 -3
  1071. package/src/cli.ts +169 -235
  1072. package/src/config/acp-schema.ts +47 -0
  1073. package/src/config/bundled-skills/_shared/CLI_RETRIEVAL_PATTERN.md +14 -12
  1074. package/src/config/bundled-skills/acp/SKILL.md +58 -0
  1075. package/src/config/bundled-skills/acp/TOOLS.json +79 -0
  1076. package/src/config/bundled-skills/{settings/tools/set-avatar.ts → acp/tools/acp-abort.ts} +2 -2
  1077. package/src/config/bundled-skills/acp/tools/acp-spawn.ts +12 -0
  1078. package/src/config/bundled-skills/acp/tools/acp-status.ts +12 -0
  1079. package/src/config/bundled-skills/app-builder/SKILL.md +63 -47
  1080. package/src/config/bundled-skills/app-builder/TOOLS.json +10 -10
  1081. package/src/config/bundled-skills/browser/SKILL.md +17 -16
  1082. package/src/config/bundled-skills/browser/TOOLS.json +16 -16
  1083. package/src/config/bundled-skills/browser/tools/browser-wait-for-download.ts +1 -1
  1084. package/src/config/bundled-skills/chatgpt-import/SKILL.md +2 -3
  1085. package/src/config/bundled-skills/chatgpt-import/TOOLS.json +1 -1
  1086. package/src/config/bundled-skills/chatgpt-import/tools/chatgpt-import.ts +1 -1
  1087. package/src/config/bundled-skills/claude-code/SKILL.md +6 -7
  1088. package/src/config/bundled-skills/claude-code/TOOLS.json +1 -1
  1089. package/src/config/bundled-skills/computer-use/SKILL.md +3 -5
  1090. package/src/config/bundled-skills/computer-use/TOOLS.json +15 -15
  1091. package/src/config/bundled-skills/contacts/SKILL.md +3 -4
  1092. package/src/config/bundled-skills/contacts/TOOLS.json +8 -4
  1093. package/src/config/bundled-skills/contacts/tools/google-contacts.ts +5 -1
  1094. package/src/config/bundled-skills/document/SKILL.md +4 -4
  1095. package/src/config/bundled-skills/document/TOOLS.json +2 -2
  1096. package/src/config/bundled-skills/followups/SKILL.md +1 -1
  1097. package/src/config/bundled-skills/followups/TOOLS.json +10 -10
  1098. package/src/config/bundled-skills/gmail/SKILL.md +32 -33
  1099. package/src/config/bundled-skills/gmail/TOOLS.json +16 -16
  1100. package/src/config/bundled-skills/gmail/tools/gmail-archive.ts +1 -1
  1101. package/src/config/bundled-skills/gmail/tools/gmail-sender-digest.ts +1 -1
  1102. package/src/config/bundled-skills/google-calendar/SKILL.md +1 -2
  1103. package/src/config/bundled-skills/google-calendar/TOOLS.json +5 -5
  1104. package/src/config/bundled-skills/google-calendar/tools/calendar-check-availability.ts +1 -1
  1105. package/src/config/bundled-skills/google-calendar/tools/calendar-create-event.ts +1 -1
  1106. package/src/config/bundled-skills/google-calendar/tools/calendar-get-event.ts +1 -1
  1107. package/src/config/bundled-skills/google-calendar/tools/calendar-list-events.ts +1 -1
  1108. package/src/config/bundled-skills/google-calendar/tools/calendar-rsvp.ts +1 -1
  1109. package/src/config/bundled-skills/google-calendar/tools/shared.ts +1 -5
  1110. package/src/config/bundled-skills/google-calendar/types.ts +1 -1
  1111. package/src/config/bundled-skills/heartbeat/SKILL.md +43 -0
  1112. package/src/config/bundled-skills/image-studio/SKILL.md +3 -4
  1113. package/src/config/bundled-skills/image-studio/TOOLS.json +2 -3
  1114. package/src/config/bundled-skills/image-studio/tools/media-generate-image.ts +44 -23
  1115. package/src/config/bundled-skills/media-processing/SKILL.md +40 -40
  1116. package/src/config/bundled-skills/media-processing/TOOLS.json +8 -8
  1117. package/src/config/bundled-skills/media-processing/__tests__/concurrency-pool.test.ts +2 -2
  1118. package/src/config/bundled-skills/media-processing/__tests__/preprocess.test.ts +1 -1
  1119. package/src/config/bundled-skills/media-processing/services/gemini-map.ts +5 -5
  1120. package/src/config/bundled-skills/media-processing/services/gemini-video.ts +2 -2
  1121. package/src/config/bundled-skills/media-processing/services/preprocess.ts +7 -3
  1122. package/src/config/bundled-skills/media-processing/services/processing-pipeline.ts +2 -2
  1123. package/src/config/bundled-skills/media-processing/services/reduce.ts +3 -3
  1124. package/src/config/bundled-skills/media-processing/tools/analyze-keyframes.ts +3 -3
  1125. package/src/config/bundled-skills/media-processing/tools/generate-clip.ts +2 -2
  1126. package/src/config/bundled-skills/media-processing/tools/query-media-events.ts +1 -1
  1127. package/src/config/bundled-skills/messaging/SKILL.md +39 -37
  1128. package/src/config/bundled-skills/messaging/TOOLS.json +11 -15
  1129. package/src/config/bundled-skills/messaging/tools/messaging-send.ts +1 -1
  1130. package/src/config/bundled-skills/messaging/tools/shared.ts +1 -1
  1131. package/src/config/bundled-skills/notifications/SKILL.md +5 -6
  1132. package/src/config/bundled-skills/notifications/TOOLS.json +3 -3
  1133. package/src/config/bundled-skills/notifications/tools/send-notification.ts +3 -3
  1134. package/src/config/bundled-skills/orchestration/SKILL.md +5 -2
  1135. package/src/config/bundled-skills/orchestration/TOOLS.json +1 -1
  1136. package/src/config/bundled-skills/phone-calls/SKILL.md +37 -21
  1137. package/src/config/bundled-skills/phone-calls/TOOLS.json +3 -3
  1138. package/src/config/bundled-skills/phone-calls/references/CONFIG.md +2 -2
  1139. package/src/config/bundled-skills/phone-calls/references/TRANSCRIPTS.md +2 -2
  1140. package/src/config/bundled-skills/phone-calls/references/TROUBLESHOOTING.md +1 -1
  1141. package/src/config/bundled-skills/playbooks/TOOLS.json +4 -4
  1142. package/src/config/bundled-skills/schedule/SKILL.md +26 -26
  1143. package/src/config/bundled-skills/schedule/TOOLS.json +5 -5
  1144. package/src/config/bundled-skills/screen-watch/SKILL.md +3 -4
  1145. package/src/config/bundled-skills/screen-watch/TOOLS.json +1 -1
  1146. package/src/config/bundled-skills/sequences/SKILL.md +2 -3
  1147. package/src/config/bundled-skills/sequences/TOOLS.json +14 -14
  1148. package/src/config/bundled-skills/sequences/tools/sequence-analytics.ts +2 -2
  1149. package/src/config/bundled-skills/sequences/tools/sequence-create.ts +2 -1
  1150. package/src/config/bundled-skills/sequences/tools/sequence-enroll.ts +2 -2
  1151. package/src/config/bundled-skills/sequences/tools/sequence-enrollment-list.ts +1 -1
  1152. package/src/config/bundled-skills/sequences/tools/sequence-get.ts +1 -1
  1153. package/src/config/bundled-skills/sequences/tools/sequence-import.ts +3 -3
  1154. package/src/config/bundled-skills/sequences/tools/sequence-list.ts +1 -1
  1155. package/src/config/bundled-skills/sequences/tools/sequence-update.ts +3 -2
  1156. package/src/config/bundled-skills/settings/SKILL.md +2 -3
  1157. package/src/config/bundled-skills/settings/TOOLS.json +3 -25
  1158. package/src/config/bundled-skills/settings/tools/open-system-settings.ts +1 -1
  1159. package/src/config/bundled-skills/skill-management/SKILL.md +0 -1
  1160. package/src/config/bundled-skills/skill-management/TOOLS.json +5 -13
  1161. package/src/config/bundled-skills/skills-catalog/SKILL.md +84 -0
  1162. package/src/config/bundled-skills/slack/SKILL.md +2 -3
  1163. package/src/config/bundled-skills/slack/TOOLS.json +8 -8
  1164. package/src/config/bundled-skills/slack/tools/slack-scan-digest.ts +3 -3
  1165. package/src/config/bundled-skills/subagent/SKILL.md +2 -2
  1166. package/src/config/bundled-skills/subagent/TOOLS.json +7 -7
  1167. package/src/config/bundled-skills/tasks/SKILL.md +1 -1
  1168. package/src/config/bundled-skills/tasks/TOOLS.json +9 -9
  1169. package/src/config/bundled-skills/transcribe/SKILL.md +5 -5
  1170. package/src/config/bundled-skills/transcribe/TOOLS.json +1 -1
  1171. package/src/config/bundled-skills/transcribe/tools/transcribe-media.ts +43 -13
  1172. package/src/config/bundled-skills/watcher/SKILL.md +4 -4
  1173. package/src/config/bundled-skills/watcher/TOOLS.json +5 -5
  1174. package/src/config/bundled-tool-registry.ts +9 -2
  1175. package/src/config/env.ts +44 -2
  1176. package/src/config/feature-flag-registry.json +185 -33
  1177. package/src/config/loader.ts +3 -0
  1178. package/src/config/raw-config-utils.ts +30 -0
  1179. package/src/config/schema-utils.ts +27 -0
  1180. package/src/config/schema.ts +54 -39
  1181. package/src/config/schemas/calls.ts +219 -152
  1182. package/src/config/schemas/channels.ts +118 -71
  1183. package/src/config/schemas/elevenlabs.ts +39 -24
  1184. package/src/config/schemas/heartbeat.ts +13 -4
  1185. package/src/config/schemas/inference.ts +155 -99
  1186. package/src/config/schemas/ingress.ts +100 -64
  1187. package/src/config/schemas/logging.ts +24 -15
  1188. package/src/config/schemas/mcp.ts +95 -44
  1189. package/src/config/schemas/memory-lifecycle.ts +70 -50
  1190. package/src/config/schemas/memory-processing.ts +46 -25
  1191. package/src/config/schemas/memory-retrieval.ts +206 -139
  1192. package/src/config/schemas/memory-storage.ts +113 -79
  1193. package/src/config/schemas/memory.ts +33 -28
  1194. package/src/config/schemas/notifications.ts +12 -7
  1195. package/src/config/schemas/platform.ts +62 -39
  1196. package/src/config/schemas/sandbox.ts +10 -5
  1197. package/src/config/schemas/security.ts +72 -41
  1198. package/src/config/schemas/services.ts +64 -0
  1199. package/src/config/schemas/skills.ts +131 -81
  1200. package/src/config/schemas/swarm.ts +78 -46
  1201. package/src/config/schemas/timeouts.ts +54 -41
  1202. package/src/config/schemas/workspace-git.ts +219 -162
  1203. package/src/config/skill-state.ts +6 -47
  1204. package/src/config/skills.ts +66 -271
  1205. package/src/config/types.ts +5 -0
  1206. package/src/contacts/contact-store.ts +82 -7
  1207. package/src/contacts/contacts-write.ts +13 -2
  1208. package/src/context/window-manager.ts +1 -1
  1209. package/src/credential-execution/approval-bridge.ts +350 -0
  1210. package/src/credential-execution/client.ts +414 -0
  1211. package/src/credential-execution/executable-discovery.ts +169 -0
  1212. package/src/credential-execution/feature-gates.ts +75 -0
  1213. package/src/credential-execution/managed-catalog.ts +155 -0
  1214. package/src/credential-execution/process-manager.ts +451 -0
  1215. package/src/daemon/approval-generators.ts +13 -7
  1216. package/src/daemon/assistant-attachments.ts +3 -3
  1217. package/src/daemon/config-watcher.ts +23 -15
  1218. package/src/daemon/context-overflow-policy.ts +5 -5
  1219. package/src/daemon/context-overflow-reducer.ts +2 -2
  1220. package/src/daemon/{session-agent-loop-handlers.ts → conversation-agent-loop-handlers.ts} +23 -23
  1221. package/src/daemon/{session-agent-loop.ts → conversation-agent-loop.ts} +99 -101
  1222. package/src/daemon/{session-attachments.ts → conversation-attachments.ts} +35 -9
  1223. package/src/daemon/{session-error.ts → conversation-error.ts} +58 -24
  1224. package/src/daemon/conversation-evictor.ts +204 -0
  1225. package/src/daemon/{session-history.ts → conversation-history.ts} +37 -33
  1226. package/src/daemon/{session-lifecycle.ts → conversation-lifecycle.ts} +16 -16
  1227. package/src/daemon/{session-memory.ts → conversation-memory.ts} +9 -8
  1228. package/src/daemon/{session-messaging.ts → conversation-messaging.ts} +9 -9
  1229. package/src/daemon/{session-notifiers.ts → conversation-notifiers.ts} +25 -25
  1230. package/src/daemon/{session-process.ts → conversation-process.ts} +128 -131
  1231. package/src/daemon/{session-queue-manager.ts → conversation-queue-manager.ts} +11 -8
  1232. package/src/daemon/{session-runtime-assembly.ts → conversation-runtime-assembly.ts} +156 -285
  1233. package/src/daemon/{session-skill-tools.ts → conversation-skill-tools.ts} +18 -18
  1234. package/src/daemon/{session-slash.ts → conversation-slash.ts} +42 -88
  1235. package/src/daemon/{session-surfaces.ts → conversation-surfaces.ts} +48 -34
  1236. package/src/daemon/{session-tool-setup.ts → conversation-tool-setup.ts} +50 -44
  1237. package/src/daemon/{session-usage.ts → conversation-usage.ts} +1 -1
  1238. package/src/daemon/{session-workspace.ts → conversation-workspace.ts} +3 -3
  1239. package/src/daemon/{session.ts → conversation.ts} +98 -73
  1240. package/src/daemon/daemon-control.ts +1 -1
  1241. package/src/daemon/date-context.ts +10 -83
  1242. package/src/daemon/doordash-steps.ts +9 -8
  1243. package/src/daemon/guardian-action-generators.ts +8 -2
  1244. package/src/daemon/handlers/config-channels.ts +19 -6
  1245. package/src/daemon/handlers/config-model.ts +33 -32
  1246. package/src/daemon/handlers/config-slack-channel.ts +35 -7
  1247. package/src/daemon/handlers/config-telegram.ts +6 -1
  1248. package/src/daemon/handlers/config-voice.ts +1 -2
  1249. package/src/daemon/handlers/{session-history.ts → conversation-history.ts} +4 -4
  1250. package/src/daemon/handlers/{sessions.ts → conversations.ts} +165 -185
  1251. package/src/daemon/handlers/recording.ts +20 -20
  1252. package/src/daemon/handlers/shared.ts +17 -17
  1253. package/src/daemon/handlers/skills.ts +168 -21
  1254. package/src/daemon/history-repair.ts +1 -1
  1255. package/src/daemon/host-bash-proxy.ts +11 -3
  1256. package/src/daemon/host-cu-proxy.ts +2 -2
  1257. package/src/daemon/host-file-proxy.ts +3 -3
  1258. package/src/daemon/lifecycle.ts +131 -82
  1259. package/src/daemon/main.ts +4 -0
  1260. package/src/daemon/media-visibility-policy.ts +10 -10
  1261. package/src/daemon/message-protocol.ts +11 -8
  1262. package/src/daemon/message-types/acp.ts +66 -0
  1263. package/src/daemon/message-types/computer-use.ts +4 -4
  1264. package/src/daemon/message-types/{sessions.ts → conversations.ts} +74 -80
  1265. package/src/daemon/message-types/documents.ts +2 -2
  1266. package/src/daemon/message-types/host-bash.ts +3 -1
  1267. package/src/daemon/message-types/host-cu.ts +1 -1
  1268. package/src/daemon/message-types/host-file.ts +3 -3
  1269. package/src/daemon/message-types/integrations.ts +2 -2
  1270. package/src/daemon/message-types/messages.ts +23 -23
  1271. package/src/daemon/message-types/notifications.ts +5 -5
  1272. package/src/daemon/message-types/settings.ts +1 -1
  1273. package/src/daemon/message-types/shared.ts +5 -3
  1274. package/src/daemon/message-types/skills.ts +1 -10
  1275. package/src/daemon/message-types/subagents.ts +2 -2
  1276. package/src/daemon/message-types/surfaces.ts +7 -7
  1277. package/src/daemon/message-types/work-items.ts +4 -4
  1278. package/src/daemon/parse-actual-tokens-from-error.test.ts +3 -7
  1279. package/src/daemon/providers-setup.ts +79 -0
  1280. package/src/daemon/seed-files.ts +7 -26
  1281. package/src/daemon/server.ts +452 -214
  1282. package/src/daemon/shutdown-handlers.ts +9 -3
  1283. package/src/daemon/startup-error.ts +126 -0
  1284. package/src/daemon/tool-side-effects.ts +42 -18
  1285. package/src/daemon/trace-emitter.ts +28 -5
  1286. package/src/daemon/verification-session-intent.ts +1 -1
  1287. package/src/daemon/watch-handler.ts +23 -21
  1288. package/src/email/feature-gate.ts +23 -0
  1289. package/src/events/domain-events.ts +3 -9
  1290. package/src/events/tool-domain-event-publisher.ts +0 -8
  1291. package/src/events/tool-metrics-listener.ts +0 -7
  1292. package/src/events/tool-permission-telemetry-listener.ts +46 -0
  1293. package/src/export/formatter.ts +1 -1
  1294. package/src/followups/followup-store.ts +8 -5
  1295. package/src/followups/types.ts +2 -2
  1296. package/src/heartbeat/heartbeat-service.ts +1 -1
  1297. package/src/hooks/discovery.ts +3 -0
  1298. package/src/hooks/manager.ts +27 -2
  1299. package/src/hooks/types.ts +4 -1
  1300. package/src/inbound/platform-callback-registration.ts +6 -2
  1301. package/src/instrument.ts +37 -19
  1302. package/src/media/app-icon-generator.ts +17 -10
  1303. package/src/media/avatar-router.ts +17 -10
  1304. package/src/media/gemini-image-service.ts +125 -21
  1305. package/src/memory/app-git-service.ts +3 -3
  1306. package/src/memory/attachments-store.ts +92 -27
  1307. package/src/memory/canonical-guardian-store.ts +37 -27
  1308. package/src/memory/channel-verification-sessions.ts +6 -6
  1309. package/src/memory/checkpoints.ts +5 -0
  1310. package/src/memory/conversation-bootstrap.ts +2 -2
  1311. package/src/memory/conversation-crud.ts +343 -23
  1312. package/src/memory/conversation-key-store.ts +40 -4
  1313. package/src/memory/conversation-queries.ts +8 -6
  1314. package/src/memory/conversation-starters-cadence.ts +74 -0
  1315. package/src/memory/conversation-title-service.ts +2 -3
  1316. package/src/memory/db-init.ts +70 -2
  1317. package/src/memory/embedding-backend.ts +71 -11
  1318. package/src/memory/external-conversation-store.ts +1 -1
  1319. package/src/memory/guardian-action-store.ts +3 -3
  1320. package/src/memory/indexer.ts +20 -9
  1321. package/src/memory/invite-store.ts +4 -4
  1322. package/src/memory/items-extractor.ts +48 -4
  1323. package/src/memory/job-handlers/backfill.ts +15 -8
  1324. package/src/memory/job-handlers/cleanup.ts +1 -1
  1325. package/src/memory/job-handlers/conversation-starters.ts +433 -0
  1326. package/src/memory/jobs-store.ts +5 -7
  1327. package/src/memory/jobs-worker.ts +10 -0
  1328. package/src/memory/lifecycle-events-store.ts +63 -0
  1329. package/src/memory/migrations/033-scoped-approval-grants.ts +4 -4
  1330. package/src/memory/migrations/102-alter-table-columns.ts +5 -0
  1331. package/src/memory/migrations/105-contacts-and-triage.ts +3 -3
  1332. package/src/memory/migrations/111-media-assets.ts +1 -106
  1333. package/src/memory/migrations/121-canonical-guardian-requests.ts +5 -5
  1334. package/src/memory/migrations/159-drop-contact-interaction-columns.ts +5 -0
  1335. package/src/memory/migrations/161-drop-orphaned-media-tables.ts +18 -0
  1336. package/src/memory/migrations/162-guardian-timestamps-epoch-ms.ts +283 -0
  1337. package/src/memory/migrations/163-rename-notification-thread-columns.ts +35 -0
  1338. package/src/memory/migrations/164-rename-conversation-type-column.ts +19 -0
  1339. package/src/memory/migrations/165-rename-inbox-thread-state-table.ts +15 -0
  1340. package/src/memory/migrations/166-rename-followups-thread-id.ts +20 -0
  1341. package/src/memory/migrations/167-rename-sequence-enrollments-thread-id.ts +20 -0
  1342. package/src/memory/migrations/168-rename-sequence-steps-reply-key.ts +17 -0
  1343. package/src/memory/migrations/169-rename-gmail-provider-key-to-google.ts +64 -0
  1344. package/src/memory/migrations/170-thread-starters-table.ts +32 -0
  1345. package/src/memory/migrations/171-capability-card-columns.ts +43 -0
  1346. package/src/memory/migrations/172-rename-created-by-session-id.ts +27 -0
  1347. package/src/memory/migrations/173-rename-source-session-id.ts +16 -0
  1348. package/src/memory/migrations/174-rename-thread-starters-table.ts +52 -0
  1349. package/src/memory/migrations/175-create-lifecycle-events.ts +15 -0
  1350. package/src/memory/migrations/176-drop-capability-card-state.ts +36 -0
  1351. package/src/memory/migrations/177-create-trace-events-table.ts +40 -0
  1352. package/src/memory/migrations/index.ts +17 -0
  1353. package/src/memory/migrations/registry.ts +32 -0
  1354. package/src/memory/retriever.test.ts +223 -96
  1355. package/src/memory/retriever.ts +115 -138
  1356. package/src/memory/schema/calls.ts +1 -1
  1357. package/src/memory/schema/contacts.ts +3 -3
  1358. package/src/memory/schema/conversations.ts +2 -2
  1359. package/src/memory/schema/guardian.ts +9 -9
  1360. package/src/memory/schema/infrastructure.ts +29 -0
  1361. package/src/memory/schema/memory-core.ts +27 -0
  1362. package/src/memory/schema/notifications.ts +5 -5
  1363. package/src/memory/schema/tasks.ts +1 -1
  1364. package/src/memory/scoped-approval-grants.ts +14 -14
  1365. package/src/memory/search/formatting.ts +23 -6
  1366. package/src/memory/search/lexical.ts +2 -0
  1367. package/src/memory/search/semantic.ts +2 -0
  1368. package/src/memory/search/staleness.ts +1 -0
  1369. package/src/memory/search/types.ts +7 -3
  1370. package/src/memory/task-memory-cleanup.ts +96 -6
  1371. package/src/memory/trace-event-store.ts +148 -0
  1372. package/src/memory/turn-events-store.ts +48 -0
  1373. package/src/messaging/providers/telegram-bot/adapter.ts +1 -1
  1374. package/src/notifications/AGENTS.md +1 -1
  1375. package/src/notifications/README.md +103 -103
  1376. package/src/notifications/adapters/slack.ts +3 -3
  1377. package/src/notifications/adapters/telegram.ts +3 -3
  1378. package/src/notifications/broadcaster.ts +40 -40
  1379. package/src/notifications/{thread-candidates.ts → conversation-candidates.ts} +18 -18
  1380. package/src/notifications/conversation-pairing.ts +35 -31
  1381. package/src/notifications/{thread-seed-composer.ts → conversation-seed-composer.ts} +9 -9
  1382. package/src/notifications/decision-engine.ts +107 -84
  1383. package/src/notifications/deliveries-store.ts +14 -14
  1384. package/src/notifications/emit-signal.ts +16 -16
  1385. package/src/notifications/events-store.ts +4 -4
  1386. package/src/notifications/signal.ts +3 -3
  1387. package/src/notifications/types.ts +16 -12
  1388. package/src/oauth/byo-connection.test.ts +1 -1
  1389. package/src/oauth/manual-token-connection.ts +49 -25
  1390. package/src/oauth/oauth-store.ts +37 -15
  1391. package/src/oauth/platform-connection.test.ts +2 -2
  1392. package/src/oauth/provider-behaviors.ts +2 -1
  1393. package/src/oauth/seed-providers.ts +3 -11
  1394. package/src/oauth/token-persistence.ts +41 -25
  1395. package/src/outbound-proxy/index.ts +27 -3
  1396. package/src/permissions/checker.ts +21 -7
  1397. package/src/permissions/defaults.ts +4 -4
  1398. package/src/permissions/prompter.ts +3 -3
  1399. package/src/permissions/secret-prompter.ts +2 -2
  1400. package/src/permissions/types.ts +2 -2
  1401. package/src/prompts/__tests__/build-cli-reference-section.test.ts +10 -40
  1402. package/src/prompts/cache-boundary.ts +8 -0
  1403. package/src/prompts/system-prompt.ts +155 -743
  1404. package/src/prompts/templates/BOOTSTRAP.md +166 -33
  1405. package/src/prompts/templates/IDENTITY.md +8 -23
  1406. package/src/prompts/templates/SOUL.md +20 -41
  1407. package/src/prompts/templates/UPDATES.md +0 -12
  1408. package/src/prompts/templates/USER.md +3 -19
  1409. package/src/prompts/update-bulletin-format.ts +16 -0
  1410. package/src/prompts/update-bulletin.ts +18 -6
  1411. package/src/prompts/user-reference.ts +14 -16
  1412. package/src/providers/anthropic/client.ts +181 -13
  1413. package/src/providers/gemini/client.ts +6 -9
  1414. package/src/providers/managed-proxy/constants.ts +1 -7
  1415. package/src/providers/managed-proxy/context.ts +26 -1
  1416. package/src/providers/model-intents.ts +5 -5
  1417. package/src/providers/openai/client.ts +10 -1
  1418. package/src/providers/openrouter/client.ts +1 -0
  1419. package/src/providers/provider-availability.ts +39 -0
  1420. package/src/providers/provider-send-message.ts +20 -6
  1421. package/src/providers/ratelimit.ts +0 -35
  1422. package/src/providers/registry.ts +119 -82
  1423. package/src/providers/retry.ts +18 -1
  1424. package/src/runtime/AGENTS.md +5 -5
  1425. package/src/runtime/access-request-helper.ts +3 -3
  1426. package/src/runtime/actor-trust-resolver.ts +2 -2
  1427. package/src/runtime/approval-conversation-turn.ts +2 -2
  1428. package/src/runtime/assistant-event-hub.ts +9 -9
  1429. package/src/runtime/assistant-event.ts +5 -5
  1430. package/src/runtime/auth/__tests__/context.test.ts +2 -2
  1431. package/src/runtime/auth/__tests__/external-assistant-id.test.ts +88 -0
  1432. package/src/runtime/auth/__tests__/guard-tests.test.ts +1 -5
  1433. package/src/runtime/auth/__tests__/local-auth-context.test.ts +4 -4
  1434. package/src/runtime/auth/__tests__/middleware.test.ts +2 -2
  1435. package/src/runtime/auth/__tests__/subject.test.ts +6 -6
  1436. package/src/runtime/auth/context.ts +1 -1
  1437. package/src/runtime/auth/credential-service.ts +1 -1
  1438. package/src/runtime/auth/external-assistant-id.ts +36 -17
  1439. package/src/runtime/auth/route-policy.ts +24 -0
  1440. package/src/runtime/auth/subject.ts +7 -7
  1441. package/src/runtime/auth/types.ts +1 -1
  1442. package/src/runtime/channel-approval-types.ts +1 -1
  1443. package/src/runtime/channel-approvals.ts +9 -6
  1444. package/src/runtime/channel-invite-transport.ts +10 -7
  1445. package/src/runtime/channel-readiness-service.ts +5 -2
  1446. package/src/runtime/channel-retry-sweep.ts +1 -1
  1447. package/src/runtime/channel-verification-service.ts +2 -2
  1448. package/src/runtime/confirmation-request-guardian-bridge.ts +4 -4
  1449. package/src/runtime/{session-approval-overrides.ts → conversation-approval-overrides.ts} +6 -6
  1450. package/src/runtime/guardian-action-grant-minter.ts +2 -4
  1451. package/src/runtime/guardian-action-service.ts +2 -2
  1452. package/src/runtime/guardian-decision-types.ts +13 -8
  1453. package/src/runtime/guardian-reply-router.ts +4 -4
  1454. package/src/runtime/guardian-vellum-migration.ts +63 -1
  1455. package/src/runtime/http-server.ts +76 -35
  1456. package/src/runtime/http-types.ts +19 -15
  1457. package/src/runtime/invite-redemption-service.ts +8 -3
  1458. package/src/runtime/local-actor-identity.ts +9 -7
  1459. package/src/runtime/migrations/vbundle-builder.ts +212 -32
  1460. package/src/runtime/migrations/vbundle-import-analyzer.ts +74 -8
  1461. package/src/runtime/migrations/vbundle-importer.ts +66 -1
  1462. package/src/runtime/migrations/vbundle-validator.ts +17 -3
  1463. package/src/runtime/pending-interactions.ts +8 -8
  1464. package/src/runtime/routes/acp-routes.ts +170 -0
  1465. package/src/runtime/routes/approval-routes.ts +3 -3
  1466. package/src/runtime/routes/approval-strategies/guardian-callback-strategy.ts +5 -5
  1467. package/src/runtime/routes/attachment-routes.ts +2 -2
  1468. package/src/runtime/routes/avatar-routes.ts +83 -0
  1469. package/src/runtime/routes/btw-routes.ts +36 -13
  1470. package/src/runtime/routes/canonical-guardian-expiry-sweep.ts +1 -1
  1471. package/src/runtime/routes/channel-route-shared.ts +5 -3
  1472. package/src/runtime/routes/channel-verification-routes.ts +22 -5
  1473. package/src/runtime/routes/conversation-management-routes.ts +298 -0
  1474. package/src/runtime/routes/{session-query-routes.ts → conversation-query-routes.ts} +23 -20
  1475. package/src/runtime/routes/conversation-routes.ts +196 -169
  1476. package/src/runtime/routes/conversation-starter-routes.ts +207 -0
  1477. package/src/runtime/routes/debug-routes.ts +8 -2
  1478. package/src/runtime/routes/diagnostics-routes.ts +16 -17
  1479. package/src/runtime/routes/events-routes.ts +1 -1
  1480. package/src/runtime/routes/guardian-action-routes.ts +4 -4
  1481. package/src/runtime/routes/guardian-approval-interception.ts +1 -1
  1482. package/src/runtime/routes/guardian-bootstrap-routes.ts +13 -9
  1483. package/src/runtime/routes/host-bash-routes.ts +1 -1
  1484. package/src/runtime/routes/host-cu-routes.ts +1 -1
  1485. package/src/runtime/routes/host-file-routes.ts +1 -1
  1486. package/src/runtime/routes/inbound-message-handler.ts +1 -1
  1487. package/src/runtime/routes/inbound-stages/background-dispatch.ts +1 -1
  1488. package/src/runtime/routes/inbound-stages/escalation-intercept.ts +2 -2
  1489. package/src/runtime/routes/inbound-stages/secret-ingress-check.ts +1 -1
  1490. package/src/runtime/routes/inbound-stages/verification-intercept.ts +1 -1
  1491. package/src/runtime/routes/log-export-routes.ts +360 -40
  1492. package/src/runtime/routes/migration-routes.ts +25 -13
  1493. package/src/runtime/routes/recording-routes.ts +5 -5
  1494. package/src/runtime/routes/schedule-routes.ts +13 -7
  1495. package/src/runtime/routes/secret-routes.ts +196 -18
  1496. package/src/runtime/routes/settings-routes.ts +31 -18
  1497. package/src/runtime/routes/skills-routes.ts +38 -0
  1498. package/src/runtime/routes/subagents-routes.ts +10 -10
  1499. package/src/runtime/routes/surface-action-routes.ts +45 -45
  1500. package/src/runtime/routes/surface-content-routes.ts +18 -18
  1501. package/src/runtime/routes/telemetry-routes.ts +53 -0
  1502. package/src/runtime/routes/trace-event-routes.ts +62 -0
  1503. package/src/runtime/routes/watch-routes.ts +6 -6
  1504. package/src/runtime/routes/work-items-routes.test.ts +109 -0
  1505. package/src/runtime/routes/work-items-routes.ts +47 -46
  1506. package/src/runtime/tool-grant-request-helper.ts +4 -4
  1507. package/src/runtime/trust-context-resolver.ts +1 -1
  1508. package/src/runtime/verification-outbound-actions.ts +47 -31
  1509. package/src/schedule/scheduler.ts +14 -12
  1510. package/src/security/credential-backend.ts +29 -5
  1511. package/src/security/encrypted-store.ts +292 -48
  1512. package/src/security/keychain-broker-client.ts +45 -12
  1513. package/src/security/secure-keys.ts +46 -0
  1514. package/src/security/token-manager.ts +67 -167
  1515. package/src/sequence/engine.ts +12 -11
  1516. package/src/sequence/reply-matcher.ts +16 -13
  1517. package/src/sequence/store.ts +10 -7
  1518. package/src/sequence/types.ts +2 -2
  1519. package/src/signals/bash.ts +4 -4
  1520. package/src/signals/cancel.ts +14 -17
  1521. package/src/signals/confirm.ts +4 -7
  1522. package/src/signals/conversation-undo.ts +16 -20
  1523. package/src/signals/event-stream.ts +187 -0
  1524. package/src/signals/shotgun.ts +200 -0
  1525. package/src/signals/trust-rule.ts +3 -6
  1526. package/src/signals/user-message.ts +146 -0
  1527. package/src/skills/catalog-install.ts +11 -1
  1528. package/src/skills/managed-store.ts +2 -13
  1529. package/src/skills/skill-memory.ts +220 -0
  1530. package/src/subagent/manager.ts +83 -75
  1531. package/src/subagent/types.ts +5 -5
  1532. package/src/swarm/backend-claude-code.ts +1 -1
  1533. package/src/tasks/SPEC.md +5 -5
  1534. package/src/tasks/task-runner.ts +1 -1
  1535. package/src/telemetry/types.ts +35 -0
  1536. package/src/telemetry/usage-telemetry-reporter.test.ts +145 -24
  1537. package/src/telemetry/usage-telemetry-reporter.ts +126 -42
  1538. package/src/tools/AGENTS.md +32 -6
  1539. package/src/tools/acp/abort.ts +32 -0
  1540. package/src/tools/acp/spawn.ts +70 -0
  1541. package/src/tools/acp/status.ts +31 -0
  1542. package/src/tools/apps/executors.ts +8 -8
  1543. package/src/tools/apps/registry.ts +1 -1
  1544. package/src/tools/assets/materialize.ts +39 -24
  1545. package/src/tools/assets/search.ts +21 -21
  1546. package/src/tools/browser/__tests__/auth-cache.test.ts +2 -2
  1547. package/src/tools/browser/__tests__/auth-detector.test.ts +4 -4
  1548. package/src/tools/browser/auth-detector.ts +6 -6
  1549. package/src/tools/browser/browser-execution.ts +76 -46
  1550. package/src/tools/browser/browser-handoff.ts +12 -9
  1551. package/src/tools/browser/browser-manager.ts +91 -81
  1552. package/src/tools/browser/browser-screencast.ts +30 -28
  1553. package/src/tools/browser/chrome-cdp.ts +5 -5
  1554. package/src/tools/browser/jit-auth.ts +2 -2
  1555. package/src/tools/browser/network-recorder.test.ts +2 -2
  1556. package/src/tools/browser/network-recorder.ts +3 -3
  1557. package/src/tools/browser/runtime-check.ts +3 -3
  1558. package/src/tools/calls/call-start.ts +1 -1
  1559. package/src/tools/calls/call-status.ts +1 -1
  1560. package/src/tools/claude-code/claude-code.ts +11 -11
  1561. package/src/tools/computer-use/definitions.ts +18 -18
  1562. package/src/tools/credential-execution/make-authenticated-request.ts +198 -0
  1563. package/src/tools/credential-execution/manage-secure-command-tool.ts +372 -0
  1564. package/src/tools/credential-execution/run-authenticated-command.ts +261 -0
  1565. package/src/tools/credentials/broker-types.ts +5 -5
  1566. package/src/tools/credentials/broker.ts +16 -16
  1567. package/src/tools/credentials/metadata-store.ts +46 -227
  1568. package/src/tools/credentials/resolve.ts +3 -2
  1569. package/src/tools/credentials/selection.ts +1 -1
  1570. package/src/tools/credentials/tool-policy.ts +1 -1
  1571. package/src/tools/credentials/vault.ts +115 -25
  1572. package/src/tools/document/document-tool.ts +3 -3
  1573. package/src/tools/execution-target.ts +2 -2
  1574. package/src/tools/executor.ts +147 -12
  1575. package/src/tools/filesystem/edit.ts +2 -2
  1576. package/src/tools/filesystem/read.ts +1 -1
  1577. package/src/tools/filesystem/write.ts +1 -1
  1578. package/src/tools/followups/followup_create.ts +8 -7
  1579. package/src/tools/followups/followup_list.ts +3 -1
  1580. package/src/tools/followups/followup_resolve.ts +8 -7
  1581. package/src/tools/host-filesystem/edit.ts +3 -2
  1582. package/src/tools/host-filesystem/read.ts +3 -2
  1583. package/src/tools/host-filesystem/write.ts +2 -2
  1584. package/src/tools/host-terminal/host-shell.ts +60 -12
  1585. package/src/tools/mcp/mcp-tool-factory.ts +7 -6
  1586. package/src/tools/memory/definitions.ts +6 -5
  1587. package/src/tools/memory/handlers.test.ts +1 -1
  1588. package/src/tools/memory/handlers.ts +1 -1
  1589. package/src/tools/network/__tests__/web-search.test.ts +3 -3
  1590. package/src/tools/network/domain-normalize.ts +2 -2
  1591. package/src/tools/network/script-proxy/session-manager.ts +292 -517
  1592. package/src/tools/network/web-fetch.ts +2 -2
  1593. package/src/tools/network/web-search.ts +7 -7
  1594. package/src/tools/permission-checker.ts +43 -28
  1595. package/src/tools/registry.ts +20 -8
  1596. package/src/tools/schedule/list.ts +2 -2
  1597. package/src/tools/schema-transforms.ts +31 -21
  1598. package/src/tools/secret-detection-handler.ts +4 -9
  1599. package/src/tools/sensitive-output-placeholders.ts +1 -1
  1600. package/src/tools/shared/filesystem/edit-engine.ts +1 -1
  1601. package/src/tools/shared/filesystem/file-ops-service.ts +3 -3
  1602. package/src/tools/shared/filesystem/image-read.ts +25 -5
  1603. package/src/tools/shared/filesystem/path-policy.ts +2 -2
  1604. package/src/tools/shared/shell-output.ts +1 -1
  1605. package/src/tools/side-effects.ts +3 -2
  1606. package/src/tools/skills/execute.ts +1 -1
  1607. package/src/tools/skills/load.ts +18 -4
  1608. package/src/tools/skills/sandbox-runner.ts +3 -4
  1609. package/src/tools/skills/scaffold-managed.ts +0 -8
  1610. package/src/tools/subagent/abort.ts +1 -1
  1611. package/src/tools/subagent/message.ts +2 -2
  1612. package/src/tools/subagent/read.ts +3 -3
  1613. package/src/tools/subagent/spawn.ts +3 -3
  1614. package/src/tools/subagent/status.ts +10 -4
  1615. package/src/tools/swarm/delegate.ts +13 -13
  1616. package/src/tools/system/avatar-generator.ts +52 -79
  1617. package/src/tools/system/request-permission.ts +5 -4
  1618. package/src/tools/terminal/backends/native.ts +51 -11
  1619. package/src/tools/terminal/backends/types.ts +7 -0
  1620. package/src/tools/terminal/parser.ts +6 -6
  1621. package/src/tools/terminal/safe-env.ts +4 -1
  1622. package/src/tools/terminal/sandbox-diagnostics.ts +1 -1
  1623. package/src/tools/terminal/shell.ts +114 -10
  1624. package/src/tools/tool-approval-handler.ts +23 -29
  1625. package/src/tools/tool-manifest.ts +45 -2
  1626. package/src/tools/types.ts +30 -7
  1627. package/src/tools/ui-surface/definitions.ts +9 -37
  1628. package/src/tools/watch/screen-watch.ts +6 -6
  1629. package/src/tools/watch/watch-state.ts +33 -26
  1630. package/src/tools/watcher/list.ts +1 -1
  1631. package/src/util/clipboard.ts +1 -1
  1632. package/src/util/device-id.ts +101 -0
  1633. package/src/util/logger.ts +7 -2
  1634. package/src/util/platform.ts +10 -0
  1635. package/src/util/retry.ts +29 -1
  1636. package/src/util/silently.ts +7 -8
  1637. package/src/watcher/engine.ts +1 -1
  1638. package/src/work-items/resolve-required-tools.test.ts +37 -0
  1639. package/src/work-items/resolve-required-tools.ts +26 -0
  1640. package/src/work-items/work-item-runner.ts +29 -27
  1641. package/src/workspace/commit-message-enrichment-service.ts +1 -1
  1642. package/src/workspace/commit-message-provider.ts +2 -2
  1643. package/src/workspace/git-service.ts +27 -14
  1644. package/src/workspace/migrations/001-avatar-rename.ts +25 -0
  1645. package/src/workspace/migrations/002-backfill-installation-id.ts +75 -0
  1646. package/src/workspace/migrations/003-seed-device-id.ts +101 -0
  1647. package/src/workspace/migrations/004-extract-collect-usage-data.ts +50 -0
  1648. package/src/workspace/migrations/005-add-send-diagnostics.ts +12 -0
  1649. package/src/workspace/migrations/006-services-config.ts +132 -0
  1650. package/src/workspace/migrations/007-web-search-provider-rename.ts +37 -0
  1651. package/src/workspace/migrations/registry.ts +22 -0
  1652. package/src/workspace/migrations/runner.ts +117 -0
  1653. package/src/workspace/migrations/types.ts +11 -0
  1654. package/src/workspace/provider-commit-message-generator.ts +7 -4
  1655. package/src/workspace/turn-commit.ts +13 -13
  1656. package/tsconfig.json +0 -1
  1657. package/src/__tests__/cli-help-reference-sync.test.ts +0 -26
  1658. package/src/__tests__/handlers-task-submit-slash.test.ts +0 -39
  1659. package/src/__tests__/onboarding-starter-tasks.test.ts +0 -190
  1660. package/src/__tests__/session-slash-known.test.ts +0 -477
  1661. package/src/__tests__/slash-commands-catalog.test.ts +0 -94
  1662. package/src/__tests__/slash-commands-parser.test.ts +0 -127
  1663. package/src/__tests__/slash-commands-resolver.test.ts +0 -231
  1664. package/src/__tests__/slash-commands-rewrite.test.ts +0 -40
  1665. package/src/cli/commands/sessions.ts +0 -253
  1666. package/src/cli/http-client.ts +0 -76
  1667. package/src/cli/reference.ts +0 -36
  1668. package/src/daemon/install-cli-launchers.ts +0 -170
  1669. package/src/daemon/session-evictor.ts +0 -203
  1670. package/src/runtime/routes/session-management-routes.ts +0 -190
  1671. package/src/skills/slash-commands.ts +0 -203
  1672. /package/src/__tests__/{script-proxy-session-runtime.test.ts → script-proxy-conversation-runtime.test.ts} +0 -0
  1673. /package/src/daemon/{session-media-retry.ts → conversation-media-retry.ts} +0 -0
@@ -309,7 +309,7 @@ function normalizeText(text: string): string {
309
309
  }
310
310
 
311
311
  // Lighter normalization for markdown that preserves indentation, multiple spaces,
312
- // and trailing whitespace all of which carry semantic meaning in markdown
312
+ // and trailing whitespace - all of which carry semantic meaning in markdown
313
313
  // (code blocks, nested lists, table alignment, line breaks).
314
314
  function normalizeMarkdown(text: string): string {
315
315
  return text
@@ -361,7 +361,7 @@ function extractHtmlMetadata(html: string): {
361
361
  const stripped = candidate.replace(/<script[\s>][\s\S]*?<\/script>/gi, "");
362
362
  const headEnd = stripped.search(/<\/head[\s>]/i);
363
363
  const searchRegion =
364
- headEnd > 0 ? stripped.slice(0, headEnd + 10) : stripped.slice(0, 50_000);
364
+ headEnd >= 0 ? stripped.slice(0, headEnd + 10) : stripped.slice(0, 50_000);
365
365
 
366
366
  const title = extractFirstMatch(
367
367
  searchRegion,
@@ -1,7 +1,7 @@
1
1
  import { getConfig } from "../../config/loader.js";
2
2
  import { RiskLevel } from "../../permissions/types.js";
3
3
  import type { ToolDefinition } from "../../providers/types.js";
4
- import { getSecureKeyAsync } from "../../security/secure-keys.js";
4
+ import { getProviderKeyAsync } from "../../security/secure-keys.js";
5
5
  import { getLogger } from "../../util/logger.js";
6
6
  import {
7
7
  DEFAULT_BASE_DELAY_MS,
@@ -43,10 +43,10 @@ interface PerplexityResponse {
43
43
 
44
44
  function getWebSearchProvider(): WebSearchProvider {
45
45
  const config = getConfig();
46
- const configured = config.webSearchProvider ?? "perplexity";
47
- // 'anthropic-native' is handled by the Anthropic client directly;
48
- // fall back to perplexity for other providers.
49
- if (configured === "anthropic-native") return "perplexity";
46
+ const configured = config.services["web-search"].provider ?? "perplexity";
47
+ // 'inference-provider-native' is handled by the inference provider client
48
+ // directly; fall back to perplexity for other providers.
49
+ if (configured === "inference-provider-native") return "perplexity";
50
50
  return configured as WebSearchProvider;
51
51
  }
52
52
 
@@ -54,11 +54,11 @@ async function getApiKey(
54
54
  provider: WebSearchProvider,
55
55
  ): Promise<string | undefined> {
56
56
  if (provider === "brave") {
57
- return (await getSecureKeyAsync("brave")) ?? undefined;
57
+ return (await getProviderKeyAsync("brave")) ?? undefined;
58
58
  }
59
59
 
60
60
  // Perplexity
61
- return (await getSecureKeyAsync("perplexity")) ?? undefined;
61
+ return (await getProviderKeyAsync("perplexity")) ?? undefined;
62
62
  }
63
63
 
64
64
  function formatBraveResults(
@@ -10,9 +10,9 @@ import type { PermissionPrompter } from "../permissions/prompter.js";
10
10
  import { addRule } from "../permissions/trust-store.js";
11
11
  import {
12
12
  getEffectiveMode,
13
- setThreadMode,
13
+ setConversationMode,
14
14
  setTimedMode,
15
- } from "../runtime/session-approval-overrides.js";
15
+ } from "../runtime/conversation-approval-overrides.js";
16
16
  import { getLogger } from "../util/logger.js";
17
17
  import { buildPolicyContext } from "./policy-context.js";
18
18
  import { isSideEffectTool } from "./side-effects.js";
@@ -89,8 +89,8 @@ export class PermissionChecker {
89
89
  context.signal,
90
90
  );
91
91
 
92
- // Private threads force prompting for side-effect tools even when a
93
- // trust/allow rule would auto-allow. Deny decisions are preserved
92
+ // Private conversations force prompting for side-effect tools even when a
93
+ // trust/allow rule would auto-allow. Deny decisions are preserved -
94
94
  // only allow → prompt promotion happens here.
95
95
  if (
96
96
  context.forcePromptSideEffects &&
@@ -99,7 +99,18 @@ export class PermissionChecker {
99
99
  ) {
100
100
  result.decision = "prompt";
101
101
  result.reason =
102
- "Private thread: side-effect tools require explicit approval";
102
+ "Private conversation: side-effect tools require explicit approval";
103
+ }
104
+
105
+ // requireFreshApproval independently promotes allow → prompt so that
106
+ // cached grants, persistent trust rules, and auto-approve shortcuts
107
+ // cannot bypass the interactive prompt. This is separate from the
108
+ // forcePromptSideEffects path above to ensure requireFreshApproval
109
+ // is self-sufficient without relying on SIDE_EFFECT_TOOLS membership.
110
+ if (context.requireFreshApproval && result.decision === "allow") {
111
+ result.decision = "prompt";
112
+ result.reason =
113
+ "Fresh approval required: per-invocation human review enforced";
103
114
  }
104
115
 
105
116
  if (result.decision === "deny") {
@@ -110,7 +121,6 @@ export class PermissionChecker {
110
121
  executionTarget,
111
122
  input,
112
123
  workingDir: context.workingDir,
113
- sessionId: context.sessionId,
114
124
  conversationId: context.conversationId,
115
125
  requestId: context.requestId,
116
126
  riskLevel,
@@ -129,10 +139,13 @@ export class PermissionChecker {
129
139
  if (result.decision === "prompt") {
130
140
  // Guardian-trust sessions (e.g. scheduled jobs, reminders) should be
131
141
  // able to use bundled tools without interactive approval. The guardian
132
- // is the owner prompting makes no sense when there is no client.
142
+ // is the owner - prompting makes no sense when there is no client.
143
+ // Exception: requireFreshApproval tools cannot be auto-approved -
144
+ // without a human present, bundle installation must be denied.
133
145
  if (
134
146
  context.isInteractive === false &&
135
- context.trustClass === "guardian"
147
+ context.trustClass === "guardian" &&
148
+ !context.requireFreshApproval
136
149
  ) {
137
150
  log.info(
138
151
  { toolName: name, riskLevel },
@@ -145,7 +158,7 @@ export class PermissionChecker {
145
158
  };
146
159
  }
147
160
 
148
- // Non-interactive sessions have no client to respond to prompts
161
+ // Non-interactive sessions have no client to respond to prompts -
149
162
  // deny immediately instead of blocking for the full permission timeout.
150
163
  if (context.isInteractive === false) {
151
164
  const durationMs = Date.now() - startTime;
@@ -159,7 +172,6 @@ export class PermissionChecker {
159
172
  executionTarget,
160
173
  input,
161
174
  workingDir: context.workingDir,
162
- sessionId: context.sessionId,
163
175
  conversationId: context.conversationId,
164
176
  requestId: context.requestId,
165
177
  riskLevel,
@@ -176,13 +188,17 @@ export class PermissionChecker {
176
188
  }
177
189
 
178
190
  // Temporary approval override: if the guardian has enabled a
179
- // conversation-scoped "allow all" mode (allow_10m or allow_thread),
191
+ // conversation-scoped "allow all" mode (allow_10m or allow_conversation),
180
192
  // skip the interactive prompt and auto-approve. Only applies to
181
- // guardian actors untrusted actors cannot leverage this to bypass
193
+ // guardian actors - untrusted actors cannot leverage this to bypass
182
194
  // guardian-required gates (those are enforced in pre-execution gates).
195
+ // Exception: requireFreshApproval tools must always show the prompt -
196
+ // cached temporary overrides cannot substitute for per-invocation
197
+ // human review.
183
198
  if (
184
199
  context.trustClass === "guardian" &&
185
- getEffectiveMode(context.conversationId) !== undefined
200
+ getEffectiveMode(context.conversationId) !== undefined &&
201
+ !context.requireFreshApproval
186
202
  ) {
187
203
  log.info(
188
204
  {
@@ -190,7 +206,7 @@ export class PermissionChecker {
190
206
  riskLevel,
191
207
  conversationId: context.conversationId,
192
208
  },
193
- "Temporary approval override active auto-approving without prompt",
209
+ "Temporary approval override active - auto-approving without prompt",
194
210
  );
195
211
  return { allowed: true, decision: "temporary_override", riskLevel };
196
212
  }
@@ -218,14 +234,16 @@ export class PermissionChecker {
218
234
  sandboxed = wrapped.sandboxed;
219
235
  }
220
236
 
221
- const persistentDecisionsAllowed = true;
237
+ const persistentDecisionsAllowed = !context.requireFreshApproval;
222
238
 
223
- // Offer temporary approval options to guardians.
239
+ // Offer temporary approval options to guardians. Suppressed when
240
+ // requireFreshApproval is true - temporary overrides would be
241
+ // misleading since future invocations still require fresh approval.
224
242
  const temporaryOptionsAvailable:
225
- | Array<"allow_10m" | "allow_thread">
243
+ | Array<"allow_10m" | "allow_conversation">
226
244
  | undefined =
227
- context.trustClass === "guardian"
228
- ? ["allow_10m", "allow_thread"]
245
+ context.trustClass === "guardian" && !context.requireFreshApproval
246
+ ? ["allow_10m", "allow_conversation"]
229
247
  : undefined;
230
248
 
231
249
  emitLifecycleEvent({
@@ -234,7 +252,6 @@ export class PermissionChecker {
234
252
  executionTarget,
235
253
  input,
236
254
  workingDir: context.workingDir,
237
- sessionId: context.sessionId,
238
255
  conversationId: context.conversationId,
239
256
  requestId: context.requestId,
240
257
  riskLevel,
@@ -250,7 +267,7 @@ export class PermissionChecker {
250
267
  toolName: name,
251
268
  input: sanitizeToolInput(name, input),
252
269
  riskLevel,
253
- sessionId: context.sessionId,
270
+ conversationId: context.conversationId,
254
271
  });
255
272
 
256
273
  const response = await this.prompter.prompt(
@@ -275,7 +292,7 @@ export class PermissionChecker {
275
292
  toolName: name,
276
293
  decision: response.decision,
277
294
  riskLevel,
278
- sessionId: context.sessionId,
295
+ conversationId: context.conversationId,
279
296
  });
280
297
 
281
298
  if (response.decision === "deny") {
@@ -298,7 +315,6 @@ export class PermissionChecker {
298
315
  executionTarget,
299
316
  input,
300
317
  workingDir: context.workingDir,
301
- sessionId: context.sessionId,
302
318
  conversationId: context.conversationId,
303
319
  requestId: context.requestId,
304
320
  riskLevel,
@@ -347,7 +363,6 @@ export class PermissionChecker {
347
363
  executionTarget,
348
364
  input,
349
365
  workingDir: context.workingDir,
350
- sessionId: context.sessionId,
351
366
  conversationId: context.conversationId,
352
367
  requestId: context.requestId,
353
368
  riskLevel,
@@ -402,7 +417,7 @@ export class PermissionChecker {
402
417
  }
403
418
 
404
419
  // Activate temporary approval mode when the user chooses a
405
- // time-limited or thread-scoped override. Subsequent tool
420
+ // time-limited or conversation-scoped override. Subsequent tool
406
421
  // invocations in this conversation will auto-approve without
407
422
  // prompting (checked above in the temporary override block).
408
423
  if (response.decision === "allow_10m") {
@@ -411,11 +426,11 @@ export class PermissionChecker {
411
426
  { toolName: name, conversationId: context.conversationId },
412
427
  "Activated timed (10m) temporary approval mode",
413
428
  );
414
- } else if (response.decision === "allow_thread") {
415
- setThreadMode(context.conversationId);
429
+ } else if (response.decision === "allow_conversation") {
430
+ setConversationMode(context.conversationId);
416
431
  log.info(
417
432
  { toolName: name, conversationId: context.conversationId },
418
- "Activated thread-scoped temporary approval mode",
433
+ "Activated conversation-scoped temporary approval mode",
419
434
  );
420
435
  }
421
436
 
@@ -65,7 +65,7 @@ export function registerSkillTools(newTools: Tool[]): Tool[] {
65
65
  );
66
66
  continue;
67
67
  }
68
- // Existing is also a skill tool only allow replacement from the same owner.
68
+ // Existing is also a skill tool - only allow replacement from the same owner.
69
69
  if (existing.ownerSkillId !== tool.ownerSkillId) {
70
70
  throw new Error(
71
71
  `Skill tool "${tool.name}" is already registered by skill "${existing.ownerSkillId}"`,
@@ -108,7 +108,7 @@ export function unregisterSkillTools(skillId: string): void {
108
108
  return;
109
109
  }
110
110
 
111
- // Last reference actually remove the tools
111
+ // Last reference - actually remove the tools
112
112
  skillRefCount.delete(skillId);
113
113
  for (const [name, tool] of tools) {
114
114
  if (tool.origin === "skill" && tool.ownerSkillId === skillId) {
@@ -210,9 +210,9 @@ export function getSkillRefCount(skillId: string): number {
210
210
  }
211
211
 
212
212
  export function getAllToolDefinitions(): ToolDefinition[] {
213
- // Exclude proxy tools (e.g. computer_use_* tools) they are projected
213
+ // Exclude proxy tools (e.g. computer_use_* tools) - they are projected
214
214
  // into sessions by the skill system, not via the global tool list.
215
- // Exclude skill-origin tools they are managed by the session-level
215
+ // Exclude skill-origin tools - they are managed by the session-level
216
216
  // skill projection system (projectSkillTools) and must not leak into
217
217
  // the base tool list, which is shared across sessions via the global
218
218
  // registry. Including them here causes "Tool names must be unique"
@@ -223,8 +223,13 @@ export function getAllToolDefinitions(): ToolDefinition[] {
223
223
  }
224
224
 
225
225
  export async function initializeTools(): Promise<void> {
226
- const { loadEagerModules, eagerModuleToolNames, explicitTools } =
227
- await import("./tool-manifest.js");
226
+ const {
227
+ loadEagerModules,
228
+ eagerModuleToolNames,
229
+ explicitTools,
230
+ getCesToolsIfEnabled,
231
+ cesTools,
232
+ } = await import("./tool-manifest.js");
228
233
 
229
234
  // Capture tool names already in the registry before any manifest
230
235
  // registrations. In production this is empty; in tests a non-skill tool
@@ -234,7 +239,7 @@ export async function initializeTools(): Promise<void> {
234
239
  // Import tool modules to trigger registration side effects.
235
240
  await loadEagerModules();
236
241
 
237
- // Explicit tool instances no side-effect import required.
242
+ // Explicit tool instances - no side-effect import required.
238
243
  for (const tool of explicitTools) {
239
244
  registerTool(tool);
240
245
  }
@@ -251,6 +256,12 @@ export async function initializeTools(): Promise<void> {
251
256
  registerTool(tool);
252
257
  }
253
258
 
259
+ // CES tools - registered only when the CES feature flag is enabled.
260
+ const activeCesTools = getCesToolsIfEnabled();
261
+ for (const tool of activeCesTools) {
262
+ registerTool(tool);
263
+ }
264
+
254
265
  registerUiSurfaceTools();
255
266
  registerAppTools();
256
267
 
@@ -267,6 +278,7 @@ export async function initializeTools(): Promise<void> {
267
278
  ...eagerModuleToolNames,
268
279
  ...explicitTools.map((t: Tool) => t.name),
269
280
  ...hostTools.map((t: Tool) => t.name),
281
+ ...cesTools.map((t: Tool) => t.name),
270
282
  ...allComputerUseTools.map((t: Tool) => t.name),
271
283
  ...allUiSurfaceTools.map((t: Tool) => t.name),
272
284
  ...coreAppProxyTools.map((t: Tool) => t.name),
@@ -286,7 +298,7 @@ export async function initializeTools(): Promise<void> {
286
298
 
287
299
  /**
288
300
  * Reset registry to its post-initializeTools() baseline. Exposed
289
- * exclusively for test isolation prevents cross-file contamination
301
+ * exclusively for test isolation - prevents cross-file contamination
290
302
  * when multiple test suites share a single Bun process.
291
303
  *
292
304
  * Restores core tools from a snapshot taken after the first
@@ -116,14 +116,14 @@ export async function executeScheduleList(
116
116
  if (oneShot) {
117
117
  const fireTime = formatLocalDate(job.nextRunAt);
118
118
  lines.push(
119
- ` - [${status}] ${job.name} (id: ${job.id}) (one-shot, ${job.mode}) fire at: ${fireTime} [${job.status}]`,
119
+ ` - [${status}] ${job.name} (id: ${job.id}) (one-shot, ${job.mode}) - fire at: ${fireTime} [${job.status}]`,
120
120
  );
121
121
  } else {
122
122
  const next = job.enabled ? formatLocalDate(job.nextRunAt) : "n/a";
123
123
  lines.push(
124
124
  ` - [${status}] ${job.name} (id: ${job.id}) ([${
125
125
  job.syntax
126
- }] ${describeSchedule(job)}, ${job.mode}) next: ${next}`,
126
+ }] ${describeSchedule(job)}, ${job.mode}) - next: ${next}`,
127
127
  );
128
128
  }
129
129
  }
@@ -1,26 +1,22 @@
1
1
  import type { ToolDefinition } from "../providers/types.js";
2
2
 
3
3
  /**
4
- * Tools that should never have a `reason` field injected into their schema.
4
+ * Tools that should never have an `activity` field injected into their schema.
5
+ * Now empty — all tools define their own `activity` property or get it injected.
5
6
  */
6
- export const REASON_SKIP_SET = new Set<string>([
7
- "skill_execute",
8
- "bash",
9
- "host_bash",
10
- "request_system_permission",
11
- ]);
7
+ export const ACTIVITY_SKIP_SET = new Set<string>();
12
8
 
13
9
  /**
14
- * Injects a `reason` string property into each tool definition's input schema,
15
- * unless the tool is in the skip set, already has a reason field, or has a
16
- * non-object schema.
10
+ * Injects an `activity` string property into each tool definition's input
11
+ * schema, unless the tool is in the skip set, already has an activity field,
12
+ * or has a non-object schema.
17
13
  *
18
- * CRITICAL: Never mutates the input definitions always returns deep clones
14
+ * CRITICAL: Never mutates the input definitions - always returns deep clones
19
15
  * for any modified definition, since `getDefinition()` returns shared refs.
20
16
  */
21
- export function injectReasonField(
17
+ export function injectActivityField(
22
18
  definitions: ToolDefinition[],
23
- skip: Set<string> = REASON_SKIP_SET,
19
+ skip: Set<string> = ACTIVITY_SKIP_SET,
24
20
  ): ToolDefinition[] {
25
21
  return definitions.map((def) => {
26
22
  if (skip.has(def.name)) {
@@ -33,15 +29,22 @@ export function injectReasonField(
33
29
  }
34
30
 
35
31
  const properties = schema.properties as Record<string, unknown>;
36
- if (schemaDefinesProperty(schema, "reason")) {
32
+ if (schemaDefinesProperty(schema, "activity")) {
37
33
  return def;
38
34
  }
39
35
 
40
36
  // Deep clone to avoid mutating shared refs
41
- const newProperties = { ...properties, reason: { type: "string" } };
37
+ const newProperties = {
38
+ ...properties,
39
+ activity: {
40
+ type: "string",
41
+ description:
42
+ "Brief, natural description of what you're doing, shown as a live status update (e.g. 'Checking your project settings')",
43
+ },
44
+ };
42
45
  const existingRequired = Array.isArray(schema.required)
43
- ? [...schema.required, "reason"]
44
- : ["reason"];
46
+ ? [...schema.required, "activity"]
47
+ : ["activity"];
45
48
 
46
49
  return {
47
50
  ...def,
@@ -57,21 +60,28 @@ export function injectReasonField(
57
60
  /**
58
61
  * Checks whether a JSON Schema defines a given property name.
59
62
  * Walks `allOf`, `oneOf`, `anyOf` recursively.
60
- * Fail-closed on `$ref`: returns false if a `$ref` is encountered.
63
+ *
64
+ * `$ref` handling is configurable via `refBehavior`:
65
+ * - `'assume-undefined'` (default): fail-closed, treat `$ref` as not defining
66
+ * the property. Good for injection (safe to double-inject).
67
+ * - `'assume-defined'`: fail-open, treat `$ref` as possibly defining the
68
+ * property. Good for stripping decisions (don't strip what the server may need).
61
69
  */
62
70
  export function schemaDefinesProperty(
63
71
  schema: unknown,
64
72
  propertyName: string,
73
+ options?: { refBehavior?: "assume-defined" | "assume-undefined" },
65
74
  ): boolean {
66
75
  if (schema == null || typeof schema !== "object") {
67
76
  return false;
68
77
  }
69
78
 
70
79
  const s = schema as Record<string, unknown>;
80
+ const refBehavior = options?.refBehavior ?? "assume-undefined";
71
81
 
72
- // Fail-closed on $ref we can't resolve it, so treat as "doesn't define it"
82
+ // $ref: we can't resolve it, so use the configured behavior
73
83
  if ("$ref" in s) {
74
- return false;
84
+ return refBehavior === "assume-defined";
75
85
  }
76
86
 
77
87
  // Check direct properties
@@ -88,7 +98,7 @@ export function schemaDefinesProperty(
88
98
  const arr = s[keyword];
89
99
  if (Array.isArray(arr)) {
90
100
  for (const member of arr) {
91
- if (schemaDefinesProperty(member, propertyName)) {
101
+ if (schemaDefinesProperty(member, propertyName, options)) {
92
102
  return true;
93
103
  }
94
104
  }
@@ -84,7 +84,6 @@ export class SecretDetectionHandler {
84
84
  executionTarget,
85
85
  input,
86
86
  workingDir: context.workingDir,
87
- sessionId: context.sessionId,
88
87
  conversationId: context.conversationId,
89
88
  requestId: context.requestId,
90
89
  matches: matchSummary,
@@ -229,7 +228,6 @@ export class SecretDetectionHandler {
229
228
  executionTarget,
230
229
  input,
231
230
  workingDir: context.workingDir,
232
- sessionId: context.sessionId,
233
231
  conversationId: context.conversationId,
234
232
  requestId: context.requestId,
235
233
  riskLevel,
@@ -244,7 +242,7 @@ export class SecretDetectionHandler {
244
242
  riskLevel,
245
243
  isError: true,
246
244
  durationMs,
247
- sessionId: context.sessionId,
245
+ conversationId: context.conversationId,
248
246
  });
249
247
 
250
248
  return { result: blockedResult, earlyReturn: true };
@@ -282,7 +280,6 @@ export class SecretDetectionHandler {
282
280
  executionTarget,
283
281
  input,
284
282
  workingDir: context.workingDir,
285
- sessionId: context.sessionId,
286
283
  conversationId: context.conversationId,
287
284
  requestId: context.requestId,
288
285
  riskLevel: RiskLevel.High,
@@ -297,7 +294,7 @@ export class SecretDetectionHandler {
297
294
  riskLevel,
298
295
  isError: true,
299
296
  durationMs,
300
- sessionId: context.sessionId,
297
+ conversationId: context.conversationId,
301
298
  });
302
299
 
303
300
  return {
@@ -318,7 +315,6 @@ export class SecretDetectionHandler {
318
315
  executionTarget,
319
316
  input: promptInput,
320
317
  workingDir: context.workingDir,
321
- sessionId: context.sessionId,
322
318
  conversationId: context.conversationId,
323
319
  requestId: context.requestId,
324
320
  riskLevel: RiskLevel.High,
@@ -352,7 +348,6 @@ export class SecretDetectionHandler {
352
348
  executionTarget,
353
349
  input,
354
350
  workingDir: context.workingDir,
355
- sessionId: context.sessionId,
356
351
  conversationId: context.conversationId,
357
352
  requestId: context.requestId,
358
353
  riskLevel: RiskLevel.High,
@@ -367,7 +362,7 @@ export class SecretDetectionHandler {
367
362
  riskLevel,
368
363
  isError: true,
369
364
  durationMs,
370
- sessionId: context.sessionId,
365
+ conversationId: context.conversationId,
371
366
  });
372
367
 
373
368
  return {
@@ -376,7 +371,7 @@ export class SecretDetectionHandler {
376
371
  };
377
372
  }
378
373
 
379
- // User allowed pass content through unchanged
374
+ // User allowed - pass content through unchanged
380
375
  return { result: execResult, earlyReturn: false };
381
376
  }
382
377
  }
@@ -43,7 +43,7 @@ const VALID_KINDS = new Set<string>(Object.keys(KIND_PREFIX));
43
43
 
44
44
  /**
45
45
  * Generate an 8-char uppercase base-36 short ID.
46
- * Provides ~41 bits of entropy sufficient for intra-request uniqueness.
46
+ * Provides ~41 bits of entropy - sufficient for intra-request uniqueness.
47
47
  */
48
48
  function generateShortId(): string {
49
49
  const chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
@@ -29,7 +29,7 @@ export type EditEngineResult =
29
29
  * Core match/replace logic shared by both sandbox and host edit tools,
30
30
  * and by the executor's preview-diff computation.
31
31
  *
32
- * This function is pure it takes file content and edit parameters and
32
+ * This function is pure - it takes file content and edit parameters and
33
33
  * returns the result without performing any I/O.
34
34
  */
35
35
  export function applyEdit(
@@ -132,7 +132,7 @@ export class FileSystemOps {
132
132
  try {
133
133
  oldContent = readFileSync(filePath, "utf-8");
134
134
  } catch {
135
- // Unreadable existing file keep oldContent as empty string.
135
+ // Unreadable existing file - keep oldContent as empty string.
136
136
  }
137
137
  }
138
138
 
@@ -167,14 +167,14 @@ export class FileSystemOps {
167
167
  }
168
168
  const filePath = pathCheck.resolved;
169
169
 
170
- // Size-check the file on disk (swallow ENOENT readFileSync gives a clearer error)
170
+ // Size-check the file on disk (swallow ENOENT - readFileSync gives a clearer error)
171
171
  try {
172
172
  const sizeErr = checkFileSizeOnDisk(filePath, this.sizeLimit);
173
173
  if (sizeErr) {
174
174
  return { ok: false, error: Err.sizeLimitExceeded(filePath, sizeErr) };
175
175
  }
176
176
  } catch {
177
- // Fall through the readFileSync below will surface NOT_FOUND.
177
+ // Fall through - the readFileSync below will surface NOT_FOUND.
178
178
  }
179
179
 
180
180
  let content: string;
@@ -14,7 +14,8 @@ export const IMAGE_EXTENSIONS = new Set([
14
14
  ".webp",
15
15
  ]);
16
16
 
17
- const MAX_SIZE_BYTES = 20 * 1024 * 1024; // 20 MB
17
+ const MAX_SIZE_BYTES = 20 * 1024 * 1024; // 20 MB — LLM API transport limit (post-optimization)
18
+ const MAX_SOURCE_SIZE_BYTES = 100 * 1024 * 1024; // 100 MB — pre-optimization guard
18
19
 
19
20
  // Images above this threshold get auto-optimized via sips (macOS) to avoid
20
21
  // sending multi-MB base64 payloads to the LLM API.
@@ -102,7 +103,7 @@ function optimizeWithSips(srcPath: string): string | null {
102
103
  * Read an image file from disk, optionally optimize it, and return a
103
104
  * ToolExecutionResult with base64-encoded image content blocks.
104
105
  *
105
- * The caller is responsible for path resolution and sandbox enforcement
106
+ * The caller is responsible for path resolution and sandbox enforcement -
106
107
  * `resolvedPath` must be an already-validated absolute path.
107
108
  */
108
109
  export function readImageFile(resolvedPath: string): ToolExecutionResult {
@@ -120,10 +121,10 @@ export function readImageFile(resolvedPath: string): ToolExecutionResult {
120
121
  return { content: `Error: ${resolvedPath} is not a file`, isError: true };
121
122
  }
122
123
 
123
- if (stat.size > MAX_SIZE_BYTES) {
124
+ if (stat.size > MAX_SOURCE_SIZE_BYTES) {
124
125
  const sizeMB = (stat.size / (1024 * 1024)).toFixed(1);
125
126
  return {
126
- content: `Error: image too large (${sizeMB} MB). Maximum is 20 MB.`,
127
+ content: `Error: image too large (${sizeMB} MB). Maximum source file size is 100 MB.`,
127
128
  isError: true,
128
129
  };
129
130
  }
@@ -139,6 +140,14 @@ export function readImageFile(resolvedPath: string): ToolExecutionResult {
139
140
  buffer = readFileSync(tmpPath) as Buffer;
140
141
  optimized = true;
141
142
  } else {
143
+ // sips unavailable — fast-fail if original file exceeds the transport limit
144
+ if (stat.size > MAX_SIZE_BYTES) {
145
+ const sizeMB = (stat.size / (1024 * 1024)).toFixed(1);
146
+ return {
147
+ content: `Error: image too large (${sizeMB} MB). Maximum is 20 MB. Image optimization (sips) is unavailable on this platform.`,
148
+ isError: true,
149
+ };
150
+ }
142
151
  buffer = readFileSync(resolvedPath) as Buffer;
143
152
  }
144
153
  } else {
@@ -157,7 +166,18 @@ export function readImageFile(resolvedPath: string): ToolExecutionResult {
157
166
  }
158
167
  }
159
168
 
160
- // Detect actual format from magic bytes — never trust the file extension
169
+ if (buffer.length > MAX_SIZE_BYTES) {
170
+ const sizeMB = (buffer.length / (1024 * 1024)).toFixed(1);
171
+ const msg = optimized
172
+ ? `Error: image too large after optimization (${sizeMB} MB). Maximum is 20 MB.`
173
+ : `Error: image too large (${sizeMB} MB). Maximum is 20 MB.`;
174
+ return {
175
+ content: msg,
176
+ isError: true,
177
+ };
178
+ }
179
+
180
+ // Detect actual format from magic bytes - never trust the file extension
161
181
  // alone, since sips converts to JPEG and files can be misnamed.
162
182
  const detectedType = detectMediaType(buffer);
163
183
  if (!detectedType) {
@@ -34,7 +34,7 @@ const CONTAINER_WORKSPACE_EXACT = "/workspace";
34
34
  *
35
35
  * For existing paths, symlinks are resolved via realpathSync so a symlink
36
36
  * pointing outside the boundary is caught. For new paths (e.g. file_write),
37
- * pass `mustExist: false` the nearest existing ancestor directory is
37
+ * pass `mustExist: false` - the nearest existing ancestor directory is
38
38
  * resolved via realpathSync to catch symlinks in parent dirs.
39
39
  *
40
40
  * Paths starting with `/workspace/` are treated as container-scoped and
@@ -71,7 +71,7 @@ export function sandboxPolicy(
71
71
  try {
72
72
  realResolved = realpathSync(resolved);
73
73
  } catch {
74
- // File doesn't exist will be caught by the tool's own existence check
74
+ // File doesn't exist - will be caught by the tool's own existence check
75
75
  realResolved = resolved;
76
76
  }
77
77
  } else {