@vellumai/assistant 0.4.55 → 0.4.56
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.
- package/ARCHITECTURE.md +157 -163
- package/Dockerfile +6 -9
- package/README.md +1 -1
- package/bun.lock +145 -112
- package/docs/architecture/integrations.md +22 -22
- package/docs/architecture/memory.md +50 -50
- package/docs/architecture/security.md +2 -2
- package/docs/credential-execution-service.md +411 -0
- package/knip.json +5 -1
- package/node_modules/@vellumai/ces-contracts/bun.lock +29 -0
- package/node_modules/@vellumai/ces-contracts/package.json +24 -0
- package/node_modules/@vellumai/ces-contracts/src/__tests__/contracts.test.ts +293 -0
- package/node_modules/@vellumai/ces-contracts/src/__tests__/grants.test.ts +686 -0
- package/node_modules/@vellumai/ces-contracts/src/error.ts +25 -0
- package/node_modules/@vellumai/ces-contracts/src/grants.ts +184 -0
- package/node_modules/@vellumai/ces-contracts/src/handles.ts +213 -0
- package/node_modules/@vellumai/ces-contracts/src/index.ts +147 -0
- package/node_modules/@vellumai/ces-contracts/src/rendering.ts +135 -0
- package/node_modules/@vellumai/ces-contracts/src/rpc.ts +511 -0
- package/node_modules/@vellumai/ces-contracts/tsconfig.json +20 -0
- package/node_modules/@vellumai/credential-storage/bun.lock +24 -0
- package/node_modules/@vellumai/credential-storage/package.json +17 -0
- package/node_modules/@vellumai/credential-storage/src/__tests__/package-boundary.test.ts +151 -0
- package/node_modules/@vellumai/credential-storage/src/index.ts +213 -0
- package/node_modules/@vellumai/credential-storage/src/oauth-runtime.ts +340 -0
- package/node_modules/@vellumai/credential-storage/src/static-credentials.ts +365 -0
- package/node_modules/@vellumai/credential-storage/tsconfig.json +20 -0
- package/node_modules/@vellumai/egress-proxy/bun.lock +24 -0
- package/node_modules/@vellumai/egress-proxy/package.json +17 -0
- package/node_modules/@vellumai/egress-proxy/src/__tests__/package-boundary.test.ts +131 -0
- package/node_modules/@vellumai/egress-proxy/src/index.ts +54 -0
- package/node_modules/@vellumai/egress-proxy/src/session-core.ts +466 -0
- package/node_modules/@vellumai/egress-proxy/src/types.ts +227 -0
- package/node_modules/@vellumai/egress-proxy/tsconfig.json +20 -0
- package/node_modules/zod/LICENSE +21 -0
- package/node_modules/zod/README.md +208 -0
- package/node_modules/zod/index.cjs +33 -0
- package/node_modules/zod/index.d.cts +4 -0
- package/node_modules/zod/index.d.ts +4 -0
- package/node_modules/zod/index.js +4 -0
- package/node_modules/zod/locales/index.cjs +17 -0
- package/node_modules/zod/locales/index.d.cts +1 -0
- package/node_modules/zod/locales/index.d.ts +1 -0
- package/node_modules/zod/locales/index.js +1 -0
- package/node_modules/zod/locales/package.json +6 -0
- package/node_modules/zod/mini/index.cjs +32 -0
- package/node_modules/zod/mini/index.d.cts +3 -0
- package/node_modules/zod/mini/index.d.ts +3 -0
- package/node_modules/zod/mini/index.js +3 -0
- package/node_modules/zod/mini/package.json +6 -0
- package/node_modules/zod/package.json +135 -0
- package/node_modules/zod/src/index.ts +4 -0
- package/node_modules/zod/src/locales/index.ts +1 -0
- package/node_modules/zod/src/mini/index.ts +3 -0
- package/node_modules/zod/src/v3/ZodError.ts +330 -0
- package/node_modules/zod/src/v3/benchmarks/datetime.ts +58 -0
- package/node_modules/zod/src/v3/benchmarks/discriminatedUnion.ts +80 -0
- package/node_modules/zod/src/v3/benchmarks/index.ts +59 -0
- package/node_modules/zod/src/v3/benchmarks/ipv4.ts +57 -0
- package/node_modules/zod/src/v3/benchmarks/object.ts +69 -0
- package/node_modules/zod/src/v3/benchmarks/primitives.ts +162 -0
- package/node_modules/zod/src/v3/benchmarks/realworld.ts +63 -0
- package/node_modules/zod/src/v3/benchmarks/string.ts +55 -0
- package/node_modules/zod/src/v3/benchmarks/union.ts +80 -0
- package/node_modules/zod/src/v3/errors.ts +13 -0
- package/node_modules/zod/src/v3/external.ts +6 -0
- package/node_modules/zod/src/v3/helpers/enumUtil.ts +17 -0
- package/node_modules/zod/src/v3/helpers/errorUtil.ts +8 -0
- package/node_modules/zod/src/v3/helpers/parseUtil.ts +176 -0
- package/node_modules/zod/src/v3/helpers/partialUtil.ts +34 -0
- package/node_modules/zod/src/v3/helpers/typeAliases.ts +2 -0
- package/node_modules/zod/src/v3/helpers/util.ts +224 -0
- package/node_modules/zod/src/v3/index.ts +4 -0
- package/node_modules/zod/src/v3/locales/en.ts +124 -0
- package/node_modules/zod/src/v3/standard-schema.ts +113 -0
- package/node_modules/zod/src/v3/tests/Mocker.ts +54 -0
- package/node_modules/zod/src/v3/tests/all-errors.test.ts +157 -0
- package/node_modules/zod/src/v3/tests/anyunknown.test.ts +28 -0
- package/node_modules/zod/src/v3/tests/array.test.ts +71 -0
- package/node_modules/zod/src/v3/tests/async-parsing.test.ts +388 -0
- package/node_modules/zod/src/v3/tests/async-refinements.test.ts +46 -0
- package/node_modules/zod/src/v3/tests/base.test.ts +29 -0
- package/node_modules/zod/src/v3/tests/bigint.test.ts +55 -0
- package/node_modules/zod/src/v3/tests/branded.test.ts +53 -0
- package/node_modules/zod/src/v3/tests/catch.test.ts +220 -0
- package/node_modules/zod/src/v3/tests/coerce.test.ts +133 -0
- package/node_modules/zod/src/v3/tests/complex.test.ts +70 -0
- package/node_modules/zod/src/v3/tests/custom.test.ts +31 -0
- package/node_modules/zod/src/v3/tests/date.test.ts +32 -0
- package/node_modules/zod/src/v3/tests/deepmasking.test.ts +186 -0
- package/node_modules/zod/src/v3/tests/default.test.ts +112 -0
- package/node_modules/zod/src/v3/tests/description.test.ts +33 -0
- package/node_modules/zod/src/v3/tests/discriminated-unions.test.ts +315 -0
- package/node_modules/zod/src/v3/tests/enum.test.ts +80 -0
- package/node_modules/zod/src/v3/tests/error.test.ts +551 -0
- package/node_modules/zod/src/v3/tests/firstparty.test.ts +87 -0
- package/node_modules/zod/src/v3/tests/firstpartyschematypes.test.ts +21 -0
- package/node_modules/zod/src/v3/tests/function.test.ts +261 -0
- package/node_modules/zod/src/v3/tests/generics.test.ts +48 -0
- package/node_modules/zod/src/v3/tests/instanceof.test.ts +37 -0
- package/node_modules/zod/src/v3/tests/intersection.test.ts +110 -0
- package/node_modules/zod/src/v3/tests/language-server.source.ts +76 -0
- package/node_modules/zod/src/v3/tests/language-server.test.ts +207 -0
- package/node_modules/zod/src/v3/tests/literal.test.ts +36 -0
- package/node_modules/zod/src/v3/tests/map.test.ts +110 -0
- package/node_modules/zod/src/v3/tests/masking.test.ts +4 -0
- package/node_modules/zod/src/v3/tests/mocker.test.ts +19 -0
- package/node_modules/zod/src/v3/tests/nan.test.ts +24 -0
- package/node_modules/zod/src/v3/tests/nativeEnum.test.ts +87 -0
- package/node_modules/zod/src/v3/tests/nullable.test.ts +42 -0
- package/node_modules/zod/src/v3/tests/number.test.ts +176 -0
- package/node_modules/zod/src/v3/tests/object-augmentation.test.ts +29 -0
- package/node_modules/zod/src/v3/tests/object-in-es5-env.test.ts +29 -0
- package/node_modules/zod/src/v3/tests/object.test.ts +434 -0
- package/node_modules/zod/src/v3/tests/optional.test.ts +42 -0
- package/node_modules/zod/src/v3/tests/parseUtil.test.ts +23 -0
- package/node_modules/zod/src/v3/tests/parser.test.ts +41 -0
- package/node_modules/zod/src/v3/tests/partials.test.ts +243 -0
- package/node_modules/zod/src/v3/tests/pickomit.test.ts +111 -0
- package/node_modules/zod/src/v3/tests/pipeline.test.ts +29 -0
- package/node_modules/zod/src/v3/tests/preprocess.test.ts +186 -0
- package/node_modules/zod/src/v3/tests/primitive.test.ts +440 -0
- package/node_modules/zod/src/v3/tests/promise.test.ts +90 -0
- package/node_modules/zod/src/v3/tests/readonly.test.ts +194 -0
- package/node_modules/zod/src/v3/tests/record.test.ts +171 -0
- package/node_modules/zod/src/v3/tests/recursive.test.ts +197 -0
- package/node_modules/zod/src/v3/tests/refine.test.ts +313 -0
- package/node_modules/zod/src/v3/tests/safeparse.test.ts +27 -0
- package/node_modules/zod/src/v3/tests/set.test.ts +142 -0
- package/node_modules/zod/src/v3/tests/standard-schema.test.ts +83 -0
- package/node_modules/zod/src/v3/tests/string.test.ts +916 -0
- package/node_modules/zod/src/v3/tests/transformer.test.ts +233 -0
- package/node_modules/zod/src/v3/tests/tuple.test.ts +90 -0
- package/node_modules/zod/src/v3/tests/unions.test.ts +57 -0
- package/node_modules/zod/src/v3/tests/validations.test.ts +133 -0
- package/node_modules/zod/src/v3/tests/void.test.ts +15 -0
- package/node_modules/zod/src/v3/types.ts +5138 -0
- package/node_modules/zod/src/v4/classic/checks.ts +32 -0
- package/node_modules/zod/src/v4/classic/coerce.ts +27 -0
- package/node_modules/zod/src/v4/classic/compat.ts +70 -0
- package/node_modules/zod/src/v4/classic/errors.ts +82 -0
- package/node_modules/zod/src/v4/classic/external.ts +51 -0
- package/node_modules/zod/src/v4/classic/from-json-schema.ts +643 -0
- package/node_modules/zod/src/v4/classic/index.ts +5 -0
- package/node_modules/zod/src/v4/classic/iso.ts +90 -0
- package/node_modules/zod/src/v4/classic/parse.ts +82 -0
- package/node_modules/zod/src/v4/classic/schemas.ts +2409 -0
- package/node_modules/zod/src/v4/classic/tests/anyunknown.test.ts +26 -0
- package/node_modules/zod/src/v4/classic/tests/apply.test.ts +59 -0
- package/node_modules/zod/src/v4/classic/tests/array.test.ts +264 -0
- package/node_modules/zod/src/v4/classic/tests/assignability.test.ts +210 -0
- package/node_modules/zod/src/v4/classic/tests/async-parsing.test.ts +381 -0
- package/node_modules/zod/src/v4/classic/tests/async-refinements.test.ts +68 -0
- package/node_modules/zod/src/v4/classic/tests/base.test.ts +7 -0
- package/node_modules/zod/src/v4/classic/tests/bigint.test.ts +54 -0
- package/node_modules/zod/src/v4/classic/tests/brand.test.ts +106 -0
- package/node_modules/zod/src/v4/classic/tests/catch.test.ts +276 -0
- package/node_modules/zod/src/v4/classic/tests/coalesce.test.ts +20 -0
- package/node_modules/zod/src/v4/classic/tests/codec-examples.test.ts +573 -0
- package/node_modules/zod/src/v4/classic/tests/codec.test.ts +562 -0
- package/node_modules/zod/src/v4/classic/tests/coerce.test.ts +160 -0
- package/node_modules/zod/src/v4/classic/tests/continuability.test.ts +374 -0
- package/node_modules/zod/src/v4/classic/tests/custom.test.ts +40 -0
- package/node_modules/zod/src/v4/classic/tests/date.test.ts +62 -0
- package/node_modules/zod/src/v4/classic/tests/datetime.test.ts +302 -0
- package/node_modules/zod/src/v4/classic/tests/default.test.ts +365 -0
- package/node_modules/zod/src/v4/classic/tests/describe-meta-checks.test.ts +27 -0
- package/node_modules/zod/src/v4/classic/tests/description.test.ts +32 -0
- package/node_modules/zod/src/v4/classic/tests/discriminated-unions.test.ts +661 -0
- package/node_modules/zod/src/v4/classic/tests/enum.test.ts +285 -0
- package/node_modules/zod/src/v4/classic/tests/error-utils.test.ts +595 -0
- package/node_modules/zod/src/v4/classic/tests/error.test.ts +711 -0
- package/node_modules/zod/src/v4/classic/tests/file.test.ts +96 -0
- package/node_modules/zod/src/v4/classic/tests/firstparty.test.ts +179 -0
- package/node_modules/zod/src/v4/classic/tests/fix-json-issue.test.ts +26 -0
- package/node_modules/zod/src/v4/classic/tests/from-json-schema.test.ts +734 -0
- package/node_modules/zod/src/v4/classic/tests/function.test.ts +360 -0
- package/node_modules/zod/src/v4/classic/tests/generics.test.ts +72 -0
- package/node_modules/zod/src/v4/classic/tests/hash.test.ts +68 -0
- package/node_modules/zod/src/v4/classic/tests/index.test.ts +939 -0
- package/node_modules/zod/src/v4/classic/tests/instanceof.test.ts +60 -0
- package/node_modules/zod/src/v4/classic/tests/intersection.test.ts +198 -0
- package/node_modules/zod/src/v4/classic/tests/json.test.ts +109 -0
- package/node_modules/zod/src/v4/classic/tests/lazy.test.ts +227 -0
- package/node_modules/zod/src/v4/classic/tests/literal.test.ts +117 -0
- package/node_modules/zod/src/v4/classic/tests/map.test.ts +330 -0
- package/node_modules/zod/src/v4/classic/tests/nan.test.ts +21 -0
- package/node_modules/zod/src/v4/classic/tests/nested-refine.test.ts +168 -0
- package/node_modules/zod/src/v4/classic/tests/nonoptional.test.ts +101 -0
- package/node_modules/zod/src/v4/classic/tests/nullable.test.ts +22 -0
- package/node_modules/zod/src/v4/classic/tests/number.test.ts +270 -0
- package/node_modules/zod/src/v4/classic/tests/object.test.ts +640 -0
- package/node_modules/zod/src/v4/classic/tests/optional.test.ts +223 -0
- package/node_modules/zod/src/v4/classic/tests/partial.test.ts +427 -0
- package/node_modules/zod/src/v4/classic/tests/pickomit.test.ts +211 -0
- package/node_modules/zod/src/v4/classic/tests/pipe.test.ts +101 -0
- package/node_modules/zod/src/v4/classic/tests/prefault.test.ts +74 -0
- package/node_modules/zod/src/v4/classic/tests/preprocess.test.ts +282 -0
- package/node_modules/zod/src/v4/classic/tests/primitive.test.ts +175 -0
- package/node_modules/zod/src/v4/classic/tests/promise.test.ts +81 -0
- package/node_modules/zod/src/v4/classic/tests/prototypes.test.ts +23 -0
- package/node_modules/zod/src/v4/classic/tests/readonly.test.ts +252 -0
- package/node_modules/zod/src/v4/classic/tests/record.test.ts +632 -0
- package/node_modules/zod/src/v4/classic/tests/recursive-types.test.ts +582 -0
- package/node_modules/zod/src/v4/classic/tests/refine.test.ts +570 -0
- package/node_modules/zod/src/v4/classic/tests/registries.test.ts +243 -0
- package/node_modules/zod/src/v4/classic/tests/set.test.ts +181 -0
- package/node_modules/zod/src/v4/classic/tests/standard-schema.test.ts +134 -0
- package/node_modules/zod/src/v4/classic/tests/string-formats.test.ts +125 -0
- package/node_modules/zod/src/v4/classic/tests/string.test.ts +1175 -0
- package/node_modules/zod/src/v4/classic/tests/stringbool.test.ts +106 -0
- package/node_modules/zod/src/v4/classic/tests/template-literal.test.ts +771 -0
- package/node_modules/zod/src/v4/classic/tests/to-json-schema-methods.test.ts +438 -0
- package/node_modules/zod/src/v4/classic/tests/to-json-schema.test.ts +2990 -0
- package/node_modules/zod/src/v4/classic/tests/transform.test.ts +361 -0
- package/node_modules/zod/src/v4/classic/tests/tuple.test.ts +183 -0
- package/node_modules/zod/src/v4/classic/tests/union.test.ts +219 -0
- package/node_modules/zod/src/v4/classic/tests/url.test.ts +13 -0
- package/node_modules/zod/src/v4/classic/tests/validations.test.ts +283 -0
- package/node_modules/zod/src/v4/classic/tests/void.test.ts +12 -0
- package/node_modules/zod/src/v4/core/api.ts +1798 -0
- package/node_modules/zod/src/v4/core/checks.ts +1293 -0
- package/node_modules/zod/src/v4/core/config.ts +15 -0
- package/node_modules/zod/src/v4/core/core.ts +138 -0
- package/node_modules/zod/src/v4/core/doc.ts +44 -0
- package/node_modules/zod/src/v4/core/errors.ts +448 -0
- package/node_modules/zod/src/v4/core/index.ts +16 -0
- package/node_modules/zod/src/v4/core/json-schema-generator.ts +126 -0
- package/node_modules/zod/src/v4/core/json-schema-processors.ts +667 -0
- package/node_modules/zod/src/v4/core/json-schema.ts +147 -0
- package/node_modules/zod/src/v4/core/parse.ts +195 -0
- package/node_modules/zod/src/v4/core/regexes.ts +183 -0
- package/node_modules/zod/src/v4/core/registries.ts +105 -0
- package/node_modules/zod/src/v4/core/schemas.ts +4538 -0
- package/node_modules/zod/src/v4/core/standard-schema.ts +159 -0
- package/node_modules/zod/src/v4/core/tests/extend.test.ts +59 -0
- package/node_modules/zod/src/v4/core/tests/index.test.ts +46 -0
- package/node_modules/zod/src/v4/core/tests/locales/be.test.ts +124 -0
- package/node_modules/zod/src/v4/core/tests/locales/en.test.ts +22 -0
- package/node_modules/zod/src/v4/core/tests/locales/es.test.ts +181 -0
- package/node_modules/zod/src/v4/core/tests/locales/he.test.ts +379 -0
- package/node_modules/zod/src/v4/core/tests/locales/nl.test.ts +46 -0
- package/node_modules/zod/src/v4/core/tests/locales/ru.test.ts +128 -0
- package/node_modules/zod/src/v4/core/tests/locales/tr.test.ts +69 -0
- package/node_modules/zod/src/v4/core/tests/locales/uz.test.ts +83 -0
- package/node_modules/zod/src/v4/core/tests/record-constructor.test.ts +67 -0
- package/node_modules/zod/src/v4/core/tests/recursive-tuples.test.ts +45 -0
- package/node_modules/zod/src/v4/core/to-json-schema.ts +613 -0
- package/node_modules/zod/src/v4/core/util.ts +966 -0
- package/node_modules/zod/src/v4/core/versions.ts +5 -0
- package/node_modules/zod/src/v4/core/zsf.ts +323 -0
- package/node_modules/zod/src/v4/index.ts +4 -0
- package/node_modules/zod/src/v4/locales/ar.ts +115 -0
- package/node_modules/zod/src/v4/locales/az.ts +111 -0
- package/node_modules/zod/src/v4/locales/be.ts +176 -0
- package/node_modules/zod/src/v4/locales/bg.ts +128 -0
- package/node_modules/zod/src/v4/locales/ca.ts +116 -0
- package/node_modules/zod/src/v4/locales/cs.ts +118 -0
- package/node_modules/zod/src/v4/locales/da.ts +123 -0
- package/node_modules/zod/src/v4/locales/de.ts +116 -0
- package/node_modules/zod/src/v4/locales/en.ts +119 -0
- package/node_modules/zod/src/v4/locales/eo.ts +118 -0
- package/node_modules/zod/src/v4/locales/es.ts +141 -0
- package/node_modules/zod/src/v4/locales/fa.ts +126 -0
- package/node_modules/zod/src/v4/locales/fi.ts +121 -0
- package/node_modules/zod/src/v4/locales/fr-CA.ts +116 -0
- package/node_modules/zod/src/v4/locales/fr.ts +116 -0
- package/node_modules/zod/src/v4/locales/he.ts +246 -0
- package/node_modules/zod/src/v4/locales/hu.ts +117 -0
- package/node_modules/zod/src/v4/locales/hy.ts +164 -0
- package/node_modules/zod/src/v4/locales/id.ts +115 -0
- package/node_modules/zod/src/v4/locales/index.ts +49 -0
- package/node_modules/zod/src/v4/locales/is.ts +119 -0
- package/node_modules/zod/src/v4/locales/it.ts +116 -0
- package/node_modules/zod/src/v4/locales/ja.ts +114 -0
- package/node_modules/zod/src/v4/locales/ka.ts +123 -0
- package/node_modules/zod/src/v4/locales/kh.ts +7 -0
- package/node_modules/zod/src/v4/locales/km.ts +119 -0
- package/node_modules/zod/src/v4/locales/ko.ts +121 -0
- package/node_modules/zod/src/v4/locales/lt.ts +239 -0
- package/node_modules/zod/src/v4/locales/mk.ts +118 -0
- package/node_modules/zod/src/v4/locales/ms.ts +115 -0
- package/node_modules/zod/src/v4/locales/nl.ts +121 -0
- package/node_modules/zod/src/v4/locales/no.ts +116 -0
- package/node_modules/zod/src/v4/locales/ota.ts +117 -0
- package/node_modules/zod/src/v4/locales/pl.ts +118 -0
- package/node_modules/zod/src/v4/locales/ps.ts +126 -0
- package/node_modules/zod/src/v4/locales/pt.ts +116 -0
- package/node_modules/zod/src/v4/locales/ru.ts +176 -0
- package/node_modules/zod/src/v4/locales/sl.ts +118 -0
- package/node_modules/zod/src/v4/locales/sv.ts +119 -0
- package/node_modules/zod/src/v4/locales/ta.ts +118 -0
- package/node_modules/zod/src/v4/locales/th.ts +119 -0
- package/node_modules/zod/src/v4/locales/tr.ts +111 -0
- package/node_modules/zod/src/v4/locales/ua.ts +7 -0
- package/node_modules/zod/src/v4/locales/uk.ts +117 -0
- package/node_modules/zod/src/v4/locales/ur.ts +119 -0
- package/node_modules/zod/src/v4/locales/uz.ts +116 -0
- package/node_modules/zod/src/v4/locales/vi.ts +117 -0
- package/node_modules/zod/src/v4/locales/yo.ts +124 -0
- package/node_modules/zod/src/v4/locales/zh-CN.ts +116 -0
- package/node_modules/zod/src/v4/locales/zh-TW.ts +115 -0
- package/node_modules/zod/src/v4/mini/checks.ts +32 -0
- package/node_modules/zod/src/v4/mini/coerce.ts +27 -0
- package/node_modules/zod/src/v4/mini/external.ts +40 -0
- package/node_modules/zod/src/v4/mini/index.ts +3 -0
- package/node_modules/zod/src/v4/mini/iso.ts +66 -0
- package/node_modules/zod/src/v4/mini/parse.ts +14 -0
- package/node_modules/zod/src/v4/mini/schemas.ts +1916 -0
- package/node_modules/zod/src/v4/mini/tests/apply.test.ts +24 -0
- package/node_modules/zod/src/v4/mini/tests/assignability.test.ts +129 -0
- package/node_modules/zod/src/v4/mini/tests/brand.test.ts +94 -0
- package/node_modules/zod/src/v4/mini/tests/checks.test.ts +144 -0
- package/node_modules/zod/src/v4/mini/tests/codec.test.ts +529 -0
- package/node_modules/zod/src/v4/mini/tests/computed.test.ts +36 -0
- package/node_modules/zod/src/v4/mini/tests/error.test.ts +22 -0
- package/node_modules/zod/src/v4/mini/tests/functions.test.ts +5 -0
- package/node_modules/zod/src/v4/mini/tests/index.test.ts +963 -0
- package/node_modules/zod/src/v4/mini/tests/number.test.ts +95 -0
- package/node_modules/zod/src/v4/mini/tests/object.test.ts +227 -0
- package/node_modules/zod/src/v4/mini/tests/prototypes.test.ts +43 -0
- package/node_modules/zod/src/v4/mini/tests/recursive-types.test.ts +275 -0
- package/node_modules/zod/src/v4/mini/tests/standard-schema.test.ts +50 -0
- package/node_modules/zod/src/v4/mini/tests/string.test.ts +347 -0
- package/node_modules/zod/src/v4-mini/index.ts +3 -0
- package/node_modules/zod/v3/ZodError.cjs +138 -0
- package/node_modules/zod/v3/ZodError.d.cts +164 -0
- package/node_modules/zod/v3/ZodError.d.ts +164 -0
- package/node_modules/zod/v3/ZodError.js +133 -0
- package/node_modules/zod/v3/errors.cjs +17 -0
- package/node_modules/zod/v3/errors.d.cts +5 -0
- package/node_modules/zod/v3/errors.d.ts +5 -0
- package/node_modules/zod/v3/errors.js +9 -0
- package/node_modules/zod/v3/external.cjs +22 -0
- package/node_modules/zod/v3/external.d.cts +6 -0
- package/node_modules/zod/v3/external.d.ts +6 -0
- package/node_modules/zod/v3/external.js +6 -0
- package/node_modules/zod/v3/helpers/enumUtil.cjs +2 -0
- package/node_modules/zod/v3/helpers/enumUtil.d.cts +8 -0
- package/node_modules/zod/v3/helpers/enumUtil.d.ts +8 -0
- package/node_modules/zod/v3/helpers/enumUtil.js +1 -0
- package/node_modules/zod/v3/helpers/errorUtil.cjs +9 -0
- package/node_modules/zod/v3/helpers/errorUtil.d.cts +9 -0
- package/node_modules/zod/v3/helpers/errorUtil.d.ts +9 -0
- package/node_modules/zod/v3/helpers/errorUtil.js +6 -0
- package/node_modules/zod/v3/helpers/parseUtil.cjs +124 -0
- package/node_modules/zod/v3/helpers/parseUtil.d.cts +78 -0
- package/node_modules/zod/v3/helpers/parseUtil.d.ts +78 -0
- package/node_modules/zod/v3/helpers/parseUtil.js +109 -0
- package/node_modules/zod/v3/helpers/partialUtil.cjs +2 -0
- package/node_modules/zod/v3/helpers/partialUtil.d.cts +8 -0
- package/node_modules/zod/v3/helpers/partialUtil.d.ts +8 -0
- package/node_modules/zod/v3/helpers/partialUtil.js +1 -0
- package/node_modules/zod/v3/helpers/typeAliases.cjs +2 -0
- package/node_modules/zod/v3/helpers/typeAliases.d.cts +2 -0
- package/node_modules/zod/v3/helpers/typeAliases.d.ts +2 -0
- package/node_modules/zod/v3/helpers/typeAliases.js +1 -0
- package/node_modules/zod/v3/helpers/util.cjs +137 -0
- package/node_modules/zod/v3/helpers/util.d.cts +85 -0
- package/node_modules/zod/v3/helpers/util.d.ts +85 -0
- package/node_modules/zod/v3/helpers/util.js +133 -0
- package/node_modules/zod/v3/index.cjs +33 -0
- package/node_modules/zod/v3/index.d.cts +4 -0
- package/node_modules/zod/v3/index.d.ts +4 -0
- package/node_modules/zod/v3/index.js +4 -0
- package/node_modules/zod/v3/locales/en.cjs +112 -0
- package/node_modules/zod/v3/locales/en.d.cts +3 -0
- package/node_modules/zod/v3/locales/en.d.ts +3 -0
- package/node_modules/zod/v3/locales/en.js +109 -0
- package/node_modules/zod/v3/package.json +6 -0
- package/node_modules/zod/v3/standard-schema.cjs +2 -0
- package/node_modules/zod/v3/standard-schema.d.cts +102 -0
- package/node_modules/zod/v3/standard-schema.d.ts +102 -0
- package/node_modules/zod/v3/standard-schema.js +1 -0
- package/node_modules/zod/v3/types.cjs +3777 -0
- package/node_modules/zod/v3/types.d.cts +1034 -0
- package/node_modules/zod/v3/types.d.ts +1034 -0
- package/node_modules/zod/v3/types.js +3695 -0
- package/node_modules/zod/v4/classic/checks.cjs +33 -0
- package/node_modules/zod/v4/classic/checks.d.cts +1 -0
- package/node_modules/zod/v4/classic/checks.d.ts +1 -0
- package/node_modules/zod/v4/classic/checks.js +1 -0
- package/node_modules/zod/v4/classic/coerce.cjs +47 -0
- package/node_modules/zod/v4/classic/coerce.d.cts +17 -0
- package/node_modules/zod/v4/classic/coerce.d.ts +17 -0
- package/node_modules/zod/v4/classic/coerce.js +17 -0
- package/node_modules/zod/v4/classic/compat.cjs +61 -0
- package/node_modules/zod/v4/classic/compat.d.cts +50 -0
- package/node_modules/zod/v4/classic/compat.d.ts +50 -0
- package/node_modules/zod/v4/classic/compat.js +31 -0
- package/node_modules/zod/v4/classic/errors.cjs +74 -0
- package/node_modules/zod/v4/classic/errors.d.cts +30 -0
- package/node_modules/zod/v4/classic/errors.d.ts +30 -0
- package/node_modules/zod/v4/classic/errors.js +48 -0
- package/node_modules/zod/v4/classic/external.cjs +73 -0
- package/node_modules/zod/v4/classic/external.d.cts +15 -0
- package/node_modules/zod/v4/classic/external.d.ts +15 -0
- package/node_modules/zod/v4/classic/external.js +20 -0
- package/node_modules/zod/v4/classic/from-json-schema.cjs +610 -0
- package/node_modules/zod/v4/classic/from-json-schema.d.cts +12 -0
- package/node_modules/zod/v4/classic/from-json-schema.d.ts +12 -0
- package/node_modules/zod/v4/classic/from-json-schema.js +584 -0
- package/node_modules/zod/v4/classic/index.cjs +33 -0
- package/node_modules/zod/v4/classic/index.d.cts +4 -0
- package/node_modules/zod/v4/classic/index.d.ts +4 -0
- package/node_modules/zod/v4/classic/index.js +4 -0
- package/node_modules/zod/v4/classic/iso.cjs +60 -0
- package/node_modules/zod/v4/classic/iso.d.cts +22 -0
- package/node_modules/zod/v4/classic/iso.d.ts +22 -0
- package/node_modules/zod/v4/classic/iso.js +30 -0
- package/node_modules/zod/v4/classic/package.json +6 -0
- package/node_modules/zod/v4/classic/parse.cjs +41 -0
- package/node_modules/zod/v4/classic/parse.d.cts +31 -0
- package/node_modules/zod/v4/classic/parse.d.ts +31 -0
- package/node_modules/zod/v4/classic/parse.js +15 -0
- package/node_modules/zod/v4/classic/schemas.cjs +1272 -0
- package/node_modules/zod/v4/classic/schemas.d.cts +739 -0
- package/node_modules/zod/v4/classic/schemas.d.ts +739 -0
- package/node_modules/zod/v4/classic/schemas.js +1157 -0
- package/node_modules/zod/v4/core/api.cjs +1222 -0
- package/node_modules/zod/v4/core/api.d.cts +304 -0
- package/node_modules/zod/v4/core/api.d.ts +304 -0
- package/node_modules/zod/v4/core/api.js +1082 -0
- package/node_modules/zod/v4/core/checks.cjs +601 -0
- package/node_modules/zod/v4/core/checks.d.cts +278 -0
- package/node_modules/zod/v4/core/checks.d.ts +278 -0
- package/node_modules/zod/v4/core/checks.js +575 -0
- package/node_modules/zod/v4/core/core.cjs +83 -0
- package/node_modules/zod/v4/core/core.d.cts +70 -0
- package/node_modules/zod/v4/core/core.d.ts +70 -0
- package/node_modules/zod/v4/core/core.js +76 -0
- package/node_modules/zod/v4/core/doc.cjs +39 -0
- package/node_modules/zod/v4/core/doc.d.cts +14 -0
- package/node_modules/zod/v4/core/doc.d.ts +14 -0
- package/node_modules/zod/v4/core/doc.js +35 -0
- package/node_modules/zod/v4/core/errors.cjs +213 -0
- package/node_modules/zod/v4/core/errors.d.cts +220 -0
- package/node_modules/zod/v4/core/errors.d.ts +220 -0
- package/node_modules/zod/v4/core/errors.js +182 -0
- package/node_modules/zod/v4/core/index.cjs +47 -0
- package/node_modules/zod/v4/core/index.d.cts +16 -0
- package/node_modules/zod/v4/core/index.d.ts +16 -0
- package/node_modules/zod/v4/core/index.js +16 -0
- package/node_modules/zod/v4/core/json-schema-generator.cjs +99 -0
- package/node_modules/zod/v4/core/json-schema-generator.d.cts +65 -0
- package/node_modules/zod/v4/core/json-schema-generator.d.ts +65 -0
- package/node_modules/zod/v4/core/json-schema-generator.js +95 -0
- package/node_modules/zod/v4/core/json-schema-processors.cjs +648 -0
- package/node_modules/zod/v4/core/json-schema-processors.d.cts +49 -0
- package/node_modules/zod/v4/core/json-schema-processors.d.ts +49 -0
- package/node_modules/zod/v4/core/json-schema-processors.js +605 -0
- package/node_modules/zod/v4/core/json-schema.cjs +2 -0
- package/node_modules/zod/v4/core/json-schema.d.cts +88 -0
- package/node_modules/zod/v4/core/json-schema.d.ts +88 -0
- package/node_modules/zod/v4/core/json-schema.js +1 -0
- package/node_modules/zod/v4/core/package.json +6 -0
- package/node_modules/zod/v4/core/parse.cjs +131 -0
- package/node_modules/zod/v4/core/parse.d.cts +49 -0
- package/node_modules/zod/v4/core/parse.d.ts +49 -0
- package/node_modules/zod/v4/core/parse.js +93 -0
- package/node_modules/zod/v4/core/regexes.cjs +166 -0
- package/node_modules/zod/v4/core/regexes.d.cts +79 -0
- package/node_modules/zod/v4/core/regexes.d.ts +79 -0
- package/node_modules/zod/v4/core/regexes.js +133 -0
- package/node_modules/zod/v4/core/registries.cjs +56 -0
- package/node_modules/zod/v4/core/registries.d.cts +35 -0
- package/node_modules/zod/v4/core/registries.d.ts +35 -0
- package/node_modules/zod/v4/core/registries.js +51 -0
- package/node_modules/zod/v4/core/schemas.cjs +2124 -0
- package/node_modules/zod/v4/core/schemas.d.cts +1146 -0
- package/node_modules/zod/v4/core/schemas.d.ts +1146 -0
- package/node_modules/zod/v4/core/schemas.js +2093 -0
- package/node_modules/zod/v4/core/standard-schema.cjs +2 -0
- package/node_modules/zod/v4/core/standard-schema.d.cts +126 -0
- package/node_modules/zod/v4/core/standard-schema.d.ts +126 -0
- package/node_modules/zod/v4/core/standard-schema.js +1 -0
- package/node_modules/zod/v4/core/to-json-schema.cjs +446 -0
- package/node_modules/zod/v4/core/to-json-schema.d.cts +114 -0
- package/node_modules/zod/v4/core/to-json-schema.d.ts +114 -0
- package/node_modules/zod/v4/core/to-json-schema.js +437 -0
- package/node_modules/zod/v4/core/util.cjs +710 -0
- package/node_modules/zod/v4/core/util.d.cts +199 -0
- package/node_modules/zod/v4/core/util.d.ts +199 -0
- package/node_modules/zod/v4/core/util.js +651 -0
- package/node_modules/zod/v4/core/versions.cjs +8 -0
- package/node_modules/zod/v4/core/versions.d.cts +5 -0
- package/node_modules/zod/v4/core/versions.d.ts +5 -0
- package/node_modules/zod/v4/core/versions.js +5 -0
- package/node_modules/zod/v4/index.cjs +22 -0
- package/node_modules/zod/v4/index.d.cts +3 -0
- package/node_modules/zod/v4/index.d.ts +3 -0
- package/node_modules/zod/v4/index.js +3 -0
- package/node_modules/zod/v4/locales/ar.cjs +133 -0
- package/node_modules/zod/v4/locales/ar.d.cts +5 -0
- package/node_modules/zod/v4/locales/ar.d.ts +4 -0
- package/node_modules/zod/v4/locales/ar.js +106 -0
- package/node_modules/zod/v4/locales/az.cjs +132 -0
- package/node_modules/zod/v4/locales/az.d.cts +5 -0
- package/node_modules/zod/v4/locales/az.d.ts +4 -0
- package/node_modules/zod/v4/locales/az.js +105 -0
- package/node_modules/zod/v4/locales/be.cjs +183 -0
- package/node_modules/zod/v4/locales/be.d.cts +5 -0
- package/node_modules/zod/v4/locales/be.d.ts +4 -0
- package/node_modules/zod/v4/locales/be.js +156 -0
- package/node_modules/zod/v4/locales/bg.cjs +147 -0
- package/node_modules/zod/v4/locales/bg.d.cts +5 -0
- package/node_modules/zod/v4/locales/bg.d.ts +4 -0
- package/node_modules/zod/v4/locales/bg.js +120 -0
- package/node_modules/zod/v4/locales/ca.cjs +134 -0
- package/node_modules/zod/v4/locales/ca.d.cts +5 -0
- package/node_modules/zod/v4/locales/ca.d.ts +4 -0
- package/node_modules/zod/v4/locales/ca.js +107 -0
- package/node_modules/zod/v4/locales/cs.cjs +138 -0
- package/node_modules/zod/v4/locales/cs.d.cts +5 -0
- package/node_modules/zod/v4/locales/cs.d.ts +4 -0
- package/node_modules/zod/v4/locales/cs.js +111 -0
- package/node_modules/zod/v4/locales/da.cjs +142 -0
- package/node_modules/zod/v4/locales/da.d.cts +5 -0
- package/node_modules/zod/v4/locales/da.d.ts +4 -0
- package/node_modules/zod/v4/locales/da.js +115 -0
- package/node_modules/zod/v4/locales/de.cjs +135 -0
- package/node_modules/zod/v4/locales/de.d.cts +5 -0
- package/node_modules/zod/v4/locales/de.d.ts +4 -0
- package/node_modules/zod/v4/locales/de.js +108 -0
- package/node_modules/zod/v4/locales/en.cjs +136 -0
- package/node_modules/zod/v4/locales/en.d.cts +5 -0
- package/node_modules/zod/v4/locales/en.d.ts +4 -0
- package/node_modules/zod/v4/locales/en.js +109 -0
- package/node_modules/zod/v4/locales/eo.cjs +136 -0
- package/node_modules/zod/v4/locales/eo.d.cts +5 -0
- package/node_modules/zod/v4/locales/eo.d.ts +4 -0
- package/node_modules/zod/v4/locales/eo.js +109 -0
- package/node_modules/zod/v4/locales/es.cjs +159 -0
- package/node_modules/zod/v4/locales/es.d.cts +5 -0
- package/node_modules/zod/v4/locales/es.d.ts +4 -0
- package/node_modules/zod/v4/locales/es.js +132 -0
- package/node_modules/zod/v4/locales/fa.cjs +141 -0
- package/node_modules/zod/v4/locales/fa.d.cts +5 -0
- package/node_modules/zod/v4/locales/fa.d.ts +4 -0
- package/node_modules/zod/v4/locales/fa.js +114 -0
- package/node_modules/zod/v4/locales/fi.cjs +139 -0
- package/node_modules/zod/v4/locales/fi.d.cts +5 -0
- package/node_modules/zod/v4/locales/fi.d.ts +4 -0
- package/node_modules/zod/v4/locales/fi.js +112 -0
- package/node_modules/zod/v4/locales/fr-CA.cjs +134 -0
- package/node_modules/zod/v4/locales/fr-CA.d.cts +5 -0
- package/node_modules/zod/v4/locales/fr-CA.d.ts +4 -0
- package/node_modules/zod/v4/locales/fr-CA.js +107 -0
- package/node_modules/zod/v4/locales/fr.cjs +135 -0
- package/node_modules/zod/v4/locales/fr.d.cts +5 -0
- package/node_modules/zod/v4/locales/fr.d.ts +4 -0
- package/node_modules/zod/v4/locales/fr.js +108 -0
- package/node_modules/zod/v4/locales/he.cjs +241 -0
- package/node_modules/zod/v4/locales/he.d.cts +5 -0
- package/node_modules/zod/v4/locales/he.d.ts +4 -0
- package/node_modules/zod/v4/locales/he.js +214 -0
- package/node_modules/zod/v4/locales/hu.cjs +135 -0
- package/node_modules/zod/v4/locales/hu.d.cts +5 -0
- package/node_modules/zod/v4/locales/hu.d.ts +4 -0
- package/node_modules/zod/v4/locales/hu.js +108 -0
- package/node_modules/zod/v4/locales/hy.cjs +174 -0
- package/node_modules/zod/v4/locales/hy.d.cts +5 -0
- package/node_modules/zod/v4/locales/hy.d.ts +4 -0
- package/node_modules/zod/v4/locales/hy.js +147 -0
- package/node_modules/zod/v4/locales/id.cjs +133 -0
- package/node_modules/zod/v4/locales/id.d.cts +5 -0
- package/node_modules/zod/v4/locales/id.d.ts +4 -0
- package/node_modules/zod/v4/locales/id.js +106 -0
- package/node_modules/zod/v4/locales/index.cjs +104 -0
- package/node_modules/zod/v4/locales/index.d.cts +49 -0
- package/node_modules/zod/v4/locales/index.d.ts +49 -0
- package/node_modules/zod/v4/locales/index.js +49 -0
- package/node_modules/zod/v4/locales/is.cjs +136 -0
- package/node_modules/zod/v4/locales/is.d.cts +5 -0
- package/node_modules/zod/v4/locales/is.d.ts +4 -0
- package/node_modules/zod/v4/locales/is.js +109 -0
- package/node_modules/zod/v4/locales/it.cjs +135 -0
- package/node_modules/zod/v4/locales/it.d.cts +5 -0
- package/node_modules/zod/v4/locales/it.d.ts +4 -0
- package/node_modules/zod/v4/locales/it.js +108 -0
- package/node_modules/zod/v4/locales/ja.cjs +134 -0
- package/node_modules/zod/v4/locales/ja.d.cts +5 -0
- package/node_modules/zod/v4/locales/ja.d.ts +4 -0
- package/node_modules/zod/v4/locales/ja.js +107 -0
- package/node_modules/zod/v4/locales/ka.cjs +139 -0
- package/node_modules/zod/v4/locales/ka.d.cts +5 -0
- package/node_modules/zod/v4/locales/ka.d.ts +4 -0
- package/node_modules/zod/v4/locales/ka.js +112 -0
- package/node_modules/zod/v4/locales/kh.cjs +12 -0
- package/node_modules/zod/v4/locales/kh.d.cts +5 -0
- package/node_modules/zod/v4/locales/kh.d.ts +5 -0
- package/node_modules/zod/v4/locales/kh.js +5 -0
- package/node_modules/zod/v4/locales/km.cjs +137 -0
- package/node_modules/zod/v4/locales/km.d.cts +5 -0
- package/node_modules/zod/v4/locales/km.d.ts +4 -0
- package/node_modules/zod/v4/locales/km.js +110 -0
- package/node_modules/zod/v4/locales/ko.cjs +138 -0
- package/node_modules/zod/v4/locales/ko.d.cts +5 -0
- package/node_modules/zod/v4/locales/ko.d.ts +4 -0
- package/node_modules/zod/v4/locales/ko.js +111 -0
- package/node_modules/zod/v4/locales/lt.cjs +230 -0
- package/node_modules/zod/v4/locales/lt.d.cts +5 -0
- package/node_modules/zod/v4/locales/lt.d.ts +4 -0
- package/node_modules/zod/v4/locales/lt.js +203 -0
- package/node_modules/zod/v4/locales/mk.cjs +136 -0
- package/node_modules/zod/v4/locales/mk.d.cts +5 -0
- package/node_modules/zod/v4/locales/mk.d.ts +4 -0
- package/node_modules/zod/v4/locales/mk.js +109 -0
- package/node_modules/zod/v4/locales/ms.cjs +134 -0
- package/node_modules/zod/v4/locales/ms.d.cts +5 -0
- package/node_modules/zod/v4/locales/ms.d.ts +4 -0
- package/node_modules/zod/v4/locales/ms.js +107 -0
- package/node_modules/zod/v4/locales/nl.cjs +137 -0
- package/node_modules/zod/v4/locales/nl.d.cts +5 -0
- package/node_modules/zod/v4/locales/nl.d.ts +4 -0
- package/node_modules/zod/v4/locales/nl.js +110 -0
- package/node_modules/zod/v4/locales/no.cjs +135 -0
- package/node_modules/zod/v4/locales/no.d.cts +5 -0
- package/node_modules/zod/v4/locales/no.d.ts +4 -0
- package/node_modules/zod/v4/locales/no.js +108 -0
- package/node_modules/zod/v4/locales/ota.cjs +136 -0
- package/node_modules/zod/v4/locales/ota.d.cts +5 -0
- package/node_modules/zod/v4/locales/ota.d.ts +4 -0
- package/node_modules/zod/v4/locales/ota.js +109 -0
- package/node_modules/zod/v4/locales/package.json +6 -0
- package/node_modules/zod/v4/locales/pl.cjs +136 -0
- package/node_modules/zod/v4/locales/pl.d.cts +5 -0
- package/node_modules/zod/v4/locales/pl.d.ts +4 -0
- package/node_modules/zod/v4/locales/pl.js +109 -0
- package/node_modules/zod/v4/locales/ps.cjs +141 -0
- package/node_modules/zod/v4/locales/ps.d.cts +5 -0
- package/node_modules/zod/v4/locales/ps.d.ts +4 -0
- package/node_modules/zod/v4/locales/ps.js +114 -0
- package/node_modules/zod/v4/locales/pt.cjs +135 -0
- package/node_modules/zod/v4/locales/pt.d.cts +5 -0
- package/node_modules/zod/v4/locales/pt.d.ts +4 -0
- package/node_modules/zod/v4/locales/pt.js +108 -0
- package/node_modules/zod/v4/locales/ru.cjs +183 -0
- package/node_modules/zod/v4/locales/ru.d.cts +5 -0
- package/node_modules/zod/v4/locales/ru.d.ts +4 -0
- package/node_modules/zod/v4/locales/ru.js +156 -0
- package/node_modules/zod/v4/locales/sl.cjs +136 -0
- package/node_modules/zod/v4/locales/sl.d.cts +5 -0
- package/node_modules/zod/v4/locales/sl.d.ts +4 -0
- package/node_modules/zod/v4/locales/sl.js +109 -0
- package/node_modules/zod/v4/locales/sv.cjs +137 -0
- package/node_modules/zod/v4/locales/sv.d.cts +5 -0
- package/node_modules/zod/v4/locales/sv.d.ts +4 -0
- package/node_modules/zod/v4/locales/sv.js +110 -0
- package/node_modules/zod/v4/locales/ta.cjs +137 -0
- package/node_modules/zod/v4/locales/ta.d.cts +5 -0
- package/node_modules/zod/v4/locales/ta.d.ts +4 -0
- package/node_modules/zod/v4/locales/ta.js +110 -0
- package/node_modules/zod/v4/locales/th.cjs +137 -0
- package/node_modules/zod/v4/locales/th.d.cts +5 -0
- package/node_modules/zod/v4/locales/th.d.ts +4 -0
- package/node_modules/zod/v4/locales/th.js +110 -0
- package/node_modules/zod/v4/locales/tr.cjs +132 -0
- package/node_modules/zod/v4/locales/tr.d.cts +5 -0
- package/node_modules/zod/v4/locales/tr.d.ts +4 -0
- package/node_modules/zod/v4/locales/tr.js +105 -0
- package/node_modules/zod/v4/locales/ua.cjs +12 -0
- package/node_modules/zod/v4/locales/ua.d.cts +5 -0
- package/node_modules/zod/v4/locales/ua.d.ts +5 -0
- package/node_modules/zod/v4/locales/ua.js +5 -0
- package/node_modules/zod/v4/locales/uk.cjs +135 -0
- package/node_modules/zod/v4/locales/uk.d.cts +5 -0
- package/node_modules/zod/v4/locales/uk.d.ts +4 -0
- package/node_modules/zod/v4/locales/uk.js +108 -0
- package/node_modules/zod/v4/locales/ur.cjs +137 -0
- package/node_modules/zod/v4/locales/ur.d.cts +5 -0
- package/node_modules/zod/v4/locales/ur.d.ts +4 -0
- package/node_modules/zod/v4/locales/ur.js +110 -0
- package/node_modules/zod/v4/locales/uz.cjs +136 -0
- package/node_modules/zod/v4/locales/uz.d.cts +5 -0
- package/node_modules/zod/v4/locales/uz.d.ts +4 -0
- package/node_modules/zod/v4/locales/uz.js +109 -0
- package/node_modules/zod/v4/locales/vi.cjs +135 -0
- package/node_modules/zod/v4/locales/vi.d.cts +5 -0
- package/node_modules/zod/v4/locales/vi.d.ts +4 -0
- package/node_modules/zod/v4/locales/vi.js +108 -0
- package/node_modules/zod/v4/locales/yo.cjs +134 -0
- package/node_modules/zod/v4/locales/yo.d.cts +5 -0
- package/node_modules/zod/v4/locales/yo.d.ts +4 -0
- package/node_modules/zod/v4/locales/yo.js +107 -0
- package/node_modules/zod/v4/locales/zh-CN.cjs +136 -0
- package/node_modules/zod/v4/locales/zh-CN.d.cts +5 -0
- package/node_modules/zod/v4/locales/zh-CN.d.ts +4 -0
- package/node_modules/zod/v4/locales/zh-CN.js +109 -0
- package/node_modules/zod/v4/locales/zh-TW.cjs +134 -0
- package/node_modules/zod/v4/locales/zh-TW.d.cts +5 -0
- package/node_modules/zod/v4/locales/zh-TW.d.ts +4 -0
- package/node_modules/zod/v4/locales/zh-TW.js +107 -0
- package/node_modules/zod/v4/mini/checks.cjs +34 -0
- package/node_modules/zod/v4/mini/checks.d.cts +1 -0
- package/node_modules/zod/v4/mini/checks.d.ts +1 -0
- package/node_modules/zod/v4/mini/checks.js +1 -0
- package/node_modules/zod/v4/mini/coerce.cjs +52 -0
- package/node_modules/zod/v4/mini/coerce.d.cts +7 -0
- package/node_modules/zod/v4/mini/coerce.d.ts +7 -0
- package/node_modules/zod/v4/mini/coerce.js +22 -0
- package/node_modules/zod/v4/mini/external.cjs +63 -0
- package/node_modules/zod/v4/mini/external.d.cts +12 -0
- package/node_modules/zod/v4/mini/external.d.ts +12 -0
- package/node_modules/zod/v4/mini/external.js +14 -0
- package/node_modules/zod/v4/mini/index.cjs +32 -0
- package/node_modules/zod/v4/mini/index.d.cts +3 -0
- package/node_modules/zod/v4/mini/index.d.ts +3 -0
- package/node_modules/zod/v4/mini/index.js +3 -0
- package/node_modules/zod/v4/mini/iso.cjs +64 -0
- package/node_modules/zod/v4/mini/iso.d.cts +22 -0
- package/node_modules/zod/v4/mini/iso.d.ts +22 -0
- package/node_modules/zod/v4/mini/iso.js +34 -0
- package/node_modules/zod/v4/mini/package.json +6 -0
- package/node_modules/zod/v4/mini/parse.cjs +16 -0
- package/node_modules/zod/v4/mini/parse.d.cts +1 -0
- package/node_modules/zod/v4/mini/parse.d.ts +1 -0
- package/node_modules/zod/v4/mini/parse.js +1 -0
- package/node_modules/zod/v4/mini/schemas.cjs +1046 -0
- package/node_modules/zod/v4/mini/schemas.d.cts +427 -0
- package/node_modules/zod/v4/mini/schemas.d.ts +427 -0
- package/node_modules/zod/v4/mini/schemas.js +925 -0
- package/node_modules/zod/v4/package.json +6 -0
- package/node_modules/zod/v4-mini/index.cjs +32 -0
- package/node_modules/zod/v4-mini/index.d.cts +3 -0
- package/node_modules/zod/v4-mini/index.d.ts +3 -0
- package/node_modules/zod/v4-mini/index.js +3 -0
- package/node_modules/zod/v4-mini/package.json +6 -0
- package/package.json +13 -2
- package/src/__tests__/acp-session.test.ts +292 -0
- package/src/__tests__/actor-token-service.test.ts +3 -3
- package/src/__tests__/always-loaded-tools-guard.test.ts +1 -1
- package/src/__tests__/anthropic-provider.test.ts +168 -46
- package/src/__tests__/app-builder-tool-scripts.test.ts +0 -1
- package/src/__tests__/approval-cascade.test.ts +121 -95
- package/src/__tests__/approval-primitive.test.ts +2 -2
- package/src/__tests__/approval-routes-http.test.ts +41 -26
- package/src/__tests__/asset-materialize-tool.test.ts +9 -16
- package/src/__tests__/asset-search-tool.test.ts +5 -12
- package/src/__tests__/assistant-attachments.test.ts +27 -0
- package/src/__tests__/assistant-event-hub.test.ts +14 -10
- package/src/__tests__/assistant-event.test.ts +9 -9
- package/src/__tests__/assistant-feature-flag-guardrails.test.ts +6 -1
- package/src/__tests__/assistant-feature-flags-integration.test.ts +139 -22
- package/src/__tests__/attachments-store.test.ts +1 -1
- package/src/__tests__/avatar-e2e.test.ts +16 -6
- package/src/__tests__/avatar-generator.test.ts +4 -7
- package/src/__tests__/browser-fill-credential.test.ts +17 -18
- package/src/__tests__/browser-skill-endstate.test.ts +1 -1
- package/src/__tests__/btw-routes.test.ts +21 -9
- package/src/__tests__/call-controller.test.ts +229 -202
- package/src/__tests__/call-pointer-messages.test.ts +12 -10
- package/src/__tests__/call-routes-http.test.ts +2 -2
- package/src/__tests__/call-start-guardian-guard.test.ts +0 -1
- package/src/__tests__/canonical-guardian-store.test.ts +8 -10
- package/src/__tests__/channel-approval-routes.test.ts +5 -5
- package/src/__tests__/channel-approval.test.ts +1 -1
- package/src/__tests__/channel-approvals.test.ts +13 -13
- package/src/__tests__/channel-guardian.test.ts +3 -3
- package/src/__tests__/channel-invite-transport.test.ts +5 -1
- package/src/__tests__/channel-readiness-routes.test.ts +4 -0
- package/src/__tests__/channel-reply-delivery.test.ts +1 -1
- package/src/__tests__/checker.test.ts +1 -1
- package/src/__tests__/claude-code-skill-regression.test.ts +67 -1
- package/src/__tests__/claude-code-tool-profiles.test.ts +1 -1
- package/src/__tests__/clipboard.test.ts +6 -6
- package/src/__tests__/commit-guarantee.test.ts +9 -9
- package/src/__tests__/commit-message-enrichment-service.test.ts +37 -6
- package/src/__tests__/computer-use-tools.test.ts +0 -1
- package/src/__tests__/config-loader-backfill.test.ts +6 -4
- package/src/__tests__/config-schema-cmd.test.ts +258 -0
- package/src/__tests__/config-schema.test.ts +38 -30
- package/src/__tests__/config-watcher.test.ts +25 -24
- package/src/__tests__/confirmation-request-guardian-bridge.test.ts +16 -14
- package/src/__tests__/contacts-tools.test.ts +0 -1
- package/src/__tests__/context-overflow-approval.test.ts +2 -2
- package/src/__tests__/{session-abort-tool-results.test.ts → conversation-abort-tool-results.test.ts} +24 -11
- package/src/__tests__/{session-agent-loop-overflow.test.ts → conversation-agent-loop-overflow.test.ts} +234 -59
- package/src/__tests__/{session-agent-loop.test.ts → conversation-agent-loop.test.ts} +77 -61
- package/src/__tests__/{session-approval-overrides.test.ts → conversation-approval-overrides.test.ts} +23 -23
- package/src/__tests__/conversation-attachments.test.ts +227 -0
- package/src/__tests__/conversation-attention-telegram.test.ts +2 -2
- package/src/__tests__/{session-confirmation-signals.test.ts → conversation-confirmation-signals.test.ts} +62 -52
- package/src/__tests__/{session-error.test.ts → conversation-error.test.ts} +65 -57
- package/src/__tests__/{session-evictor.test.ts → conversation-evictor.test.ts} +21 -17
- package/src/__tests__/{session-history-web-search.test.ts → conversation-history-web-search.test.ts} +34 -10
- package/src/__tests__/{session-init.benchmark.test.ts → conversation-init.benchmark.test.ts} +23 -23
- package/src/__tests__/{session-load-history-repair.test.ts → conversation-load-history-repair.test.ts} +38 -38
- package/src/__tests__/{session-media-retry.test.ts → conversation-media-retry.test.ts} +1 -1
- package/src/__tests__/{session-messaging-secret-redirect.test.ts → conversation-messaging-secret-redirect.test.ts} +1 -1
- package/src/__tests__/conversation-pairing.test.ts +46 -46
- package/src/__tests__/{session-pre-run-repair.test.ts → conversation-pre-run-repair.test.ts} +24 -11
- package/src/__tests__/{session-provider-retry-repair.test.ts → conversation-provider-retry-repair.test.ts} +59 -46
- package/src/__tests__/{session-queue.test.ts → conversation-queue.test.ts} +241 -220
- package/src/__tests__/conversation-routes-guardian-reply.test.ts +26 -26
- package/src/__tests__/conversation-routes-slash-commands.test.ts +33 -56
- package/src/__tests__/{session-runtime-assembly.test.ts → conversation-runtime-assembly.test.ts} +2 -2
- package/src/__tests__/{session-runtime-workspace.test.ts → conversation-runtime-workspace.test.ts} +1 -1
- package/src/__tests__/{thread-seed-composer.test.ts → conversation-seed-composer.test.ts} +50 -48
- package/src/__tests__/{session-skill-tools.test.ts → conversation-skill-tools.test.ts} +11 -13
- package/src/__tests__/{session-slash-queue.test.ts → conversation-slash-queue.test.ts} +55 -46
- package/src/__tests__/{session-slash-unknown.test.ts → conversation-slash-unknown.test.ts} +31 -75
- package/src/__tests__/conversation-store.test.ts +61 -55
- package/src/__tests__/{session-surfaces-deselection.test.ts → conversation-surfaces-deselection.test.ts} +5 -5
- package/src/__tests__/{session-surfaces-task-progress.test.ts → conversation-surfaces-task-progress.test.ts} +7 -7
- package/src/__tests__/{session-tool-setup-app-refresh.test.ts → conversation-tool-setup-app-refresh.test.ts} +5 -5
- package/src/__tests__/{session-tool-setup-memory-scope.test.ts → conversation-tool-setup-memory-scope.test.ts} +4 -4
- package/src/__tests__/{session-tool-setup-side-effect-flag.test.ts → conversation-tool-setup-side-effect-flag.test.ts} +4 -4
- package/src/__tests__/{session-tool-setup-tools-disabled.test.ts → conversation-tool-setup-tools-disabled.test.ts} +3 -3
- package/src/__tests__/{session-undo.test.ts → conversation-undo.test.ts} +1 -1
- package/src/__tests__/conversation-unread-route.test.ts +4 -0
- package/src/__tests__/{session-usage.test.ts → conversation-usage.test.ts} +1 -1
- package/src/__tests__/{session-workspace-cache-state.test.ts → conversation-workspace-cache-state.test.ts} +29 -36
- package/src/__tests__/{session-workspace-injection.test.ts → conversation-workspace-injection.test.ts} +58 -51
- package/src/__tests__/{session-workspace-tool-tracking.test.ts → conversation-workspace-tool-tracking.test.ts} +54 -47
- package/src/__tests__/credential-execution-admin-cli.test.ts +504 -0
- package/src/__tests__/credential-execution-api-key-propagation.test.ts +309 -0
- package/src/__tests__/credential-execution-approval-bridge.test.ts +535 -0
- package/src/__tests__/credential-execution-client.test.ts +380 -0
- package/src/__tests__/credential-execution-feature-gates.test.ts +169 -0
- package/src/__tests__/credential-execution-managed-contract.test.ts +526 -0
- package/src/__tests__/credential-execution-shell-lockdown.test.ts +149 -0
- package/src/__tests__/credential-execution-tools.test.ts +279 -0
- package/src/__tests__/credential-security-e2e.test.ts +0 -1
- package/src/__tests__/credential-security-invariants.test.ts +4 -8
- package/src/__tests__/credential-storage-oauth-compat.test.ts +606 -0
- package/src/__tests__/credential-storage-static-compat.test.ts +396 -0
- package/src/__tests__/credential-vault-unit.test.ts +0 -1
- package/src/__tests__/credential-vault.test.ts +0 -1
- package/src/__tests__/credentials-cli.test.ts +10 -22
- package/src/__tests__/cu-unified-flow.test.ts +8 -6
- package/src/__tests__/daemon-assistant-events.test.ts +15 -12
- package/src/__tests__/delete-managed-skill-tool.test.ts +0 -1
- package/src/__tests__/diagnostics-export.test.ts +30 -0
- package/src/__tests__/dynamic-page-surface.test.ts +2 -2
- package/src/__tests__/dynamic-skill-workflow-prompt.test.ts +19 -5
- package/src/__tests__/emit-signal-routing-intent.test.ts +1 -1
- package/src/__tests__/event-bus.test.ts +2 -6
- package/src/__tests__/file-edit-tool.test.ts +0 -1
- package/src/__tests__/file-read-tool.test.ts +0 -1
- package/src/__tests__/file-write-tool.test.ts +0 -1
- package/src/__tests__/fixtures/mock-signup-server.ts +2 -2
- package/src/__tests__/followup-tools.test.ts +25 -26
- package/src/__tests__/frontmatter.test.ts +12 -10
- package/src/__tests__/guardian-action-late-reply.test.ts +1 -1
- package/src/__tests__/guardian-action-no-hardcoded-copy.test.ts +1 -1
- package/src/__tests__/guardian-decision-primitive-canonical.test.ts +15 -15
- package/src/__tests__/guardian-dispatch.test.ts +9 -9
- package/src/__tests__/guardian-grant-minting.test.ts +5 -5
- package/src/__tests__/guardian-question-copy.test.ts +10 -8
- package/src/__tests__/guardian-routing-invariants.test.ts +61 -61
- package/src/__tests__/guardian-routing-state.test.ts +1 -1
- package/src/__tests__/guardian-verification-voice-binding.test.ts +1 -1
- package/src/__tests__/handlers-user-message-approval-consumption.test.ts +20 -16
- package/src/__tests__/headless-browser-interactions.test.ts +18 -17
- package/src/__tests__/headless-browser-navigate.test.ts +0 -1
- package/src/__tests__/headless-browser-read-tools.test.ts +5 -6
- package/src/__tests__/headless-browser-snapshot.test.ts +12 -9
- package/src/__tests__/heartbeat-service.test.ts +5 -4
- package/src/__tests__/hooks-ts-runner.test.ts +10 -4
- package/src/__tests__/host-bash-proxy.test.ts +50 -1
- package/src/__tests__/host-cu-proxy.test.ts +1 -1
- package/src/__tests__/host-file-edit-tool.test.ts +0 -1
- package/src/__tests__/host-file-proxy.test.ts +1 -1
- package/src/__tests__/host-file-read-tool.test.ts +0 -1
- package/src/__tests__/host-file-write-tool.test.ts +0 -1
- package/src/__tests__/host-shell-tool.test.ts +64 -5
- package/src/__tests__/http-user-message-parity.test.ts +32 -19
- package/src/__tests__/intent-routing.test.ts +71 -84
- package/src/__tests__/invite-redemption-service.test.ts +35 -0
- package/src/__tests__/keychain-broker-client.test.ts +150 -0
- package/src/__tests__/log-export-workspace.test.ts +133 -60
- package/src/__tests__/managed-credential-catalog-cli.test.ts +349 -0
- package/src/__tests__/managed-skill-lifecycle.test.ts +14 -2
- package/src/__tests__/managed-store.test.ts +0 -38
- package/src/__tests__/media-generate-image.test.ts +19 -2
- package/src/__tests__/media-reuse-story.e2e.test.ts +82 -70
- package/src/__tests__/media-visibility-policy.test.ts +10 -10
- package/src/__tests__/memory-query-builder.test.ts +2 -2
- package/src/__tests__/memory-regressions.test.ts +67 -30
- package/src/__tests__/messaging-send-tool.test.ts +0 -2
- package/src/__tests__/no-domain-routing-in-prompt-guard.test.ts +51 -0
- package/src/__tests__/notification-broadcaster.test.ts +42 -40
- package/src/__tests__/{notification-thread-candidate-validation.test.ts → notification-conversation-candidate-validation.test.ts} +26 -24
- package/src/__tests__/{notification-thread-candidates.test.ts → notification-conversation-candidates.test.ts} +15 -15
- package/src/__tests__/notification-decision-fallback.test.ts +6 -6
- package/src/__tests__/notification-decision-identity.test.ts +209 -0
- package/src/__tests__/notification-decision-strategy.test.ts +40 -38
- package/src/__tests__/notification-deep-link.test.ts +18 -18
- package/src/__tests__/notification-guardian-path.test.ts +13 -10
- package/src/__tests__/notification-telegram-adapter.test.ts +5 -5
- package/src/__tests__/oauth-store.test.ts +1 -5
- package/src/__tests__/permission-types.test.ts +1 -1
- package/src/__tests__/playbook-execution.test.ts +0 -1
- package/src/__tests__/playbook-tools.test.ts +0 -1
- package/src/__tests__/provider-commit-message-generator.test.ts +7 -6
- package/src/__tests__/provider-fail-open-selection.test.ts +22 -28
- package/src/__tests__/provider-managed-proxy-integration.test.ts +35 -56
- package/src/__tests__/provider-registry-ollama.test.ts +13 -2
- package/src/__tests__/proxy-approval-callback.test.ts +2 -2
- package/src/__tests__/recording-handler.test.ts +20 -20
- package/src/__tests__/relay-server.test.ts +8 -5
- package/src/__tests__/require-fresh-approval.test.ts +532 -0
- package/src/__tests__/resolve-trust-class.test.ts +2 -2
- package/src/__tests__/runtime-events-sse-parity.test.ts +21 -21
- package/src/__tests__/runtime-events-sse.test.ts +15 -7
- package/src/__tests__/scaffold-managed-skill-tool.test.ts +1 -4
- package/src/__tests__/schedule-tools.test.ts +0 -1
- package/src/__tests__/scoped-approval-grants.test.ts +6 -6
- package/src/__tests__/scoped-grant-security-matrix.test.ts +1 -1
- package/src/__tests__/{script-proxy-session-manager.test.ts → script-proxy-conversation-manager.test.ts} +4 -1
- package/src/__tests__/secret-onetime-send.test.ts +0 -4
- package/src/__tests__/secret-response-routing.test.ts +1 -1
- package/src/__tests__/secret-routes-managed-proxy.test.ts +79 -2
- package/src/__tests__/secret-scanner-executor.test.ts +0 -2
- package/src/__tests__/send-endpoint-busy.test.ts +73 -60
- package/src/__tests__/send-notification-tool.test.ts +1 -3
- package/src/__tests__/sequence-store.test.ts +5 -5
- package/src/__tests__/shell-credential-ref.test.ts +1 -2
- package/src/__tests__/shell-tool-proxy-mode.test.ts +2 -3
- package/src/__tests__/skill-feature-flags-integration.test.ts +1 -2
- package/src/__tests__/skill-feature-flags.test.ts +7 -8
- package/src/__tests__/skill-include-graph.test.ts +1 -2
- package/src/__tests__/skill-load-feature-flag.test.ts +10 -11
- package/src/__tests__/skill-load-tool.test.ts +19 -15
- package/src/__tests__/skill-projection-feature-flag.test.ts +4 -6
- package/src/__tests__/skill-projection.benchmark.test.ts +3 -5
- package/src/__tests__/skill-script-runner-host.test.ts +3 -4
- package/src/__tests__/skill-script-runner-sandbox.test.ts +3 -4
- package/src/__tests__/skill-script-runner.test.ts +0 -1
- package/src/__tests__/skill-tool-factory.test.ts +0 -1
- package/src/__tests__/skills.test.ts +0 -37
- package/src/__tests__/slack-skill.test.ts +0 -4
- package/src/__tests__/starter-task-flow.test.ts +3 -3
- package/src/__tests__/subagent-manager-notify.test.ts +45 -40
- package/src/__tests__/subagent-tools.test.ts +78 -69
- package/src/__tests__/subagent-types.test.ts +3 -3
- package/src/__tests__/surface-mutex-cleanup.test.ts +1 -1
- package/src/__tests__/{swarm-session-integration.test.ts → swarm-conversation-integration.test.ts} +13 -1
- package/src/__tests__/swarm-recursion.test.ts +21 -9
- package/src/__tests__/swarm-tool.test.ts +14 -1
- package/src/__tests__/system-prompt.test.ts +34 -16
- package/src/__tests__/task-compiler.test.ts +1 -1
- package/src/__tests__/task-management-tools.test.ts +1 -2
- package/src/__tests__/terminal-sandbox.test.ts +6 -0
- package/src/__tests__/terminal-tools.test.ts +1 -1
- package/src/__tests__/token-estimator-accuracy.benchmark.test.ts +2 -2
- package/src/__tests__/tool-approval-handler.test.ts +2 -3
- package/src/__tests__/tool-audit-listener.test.ts +0 -6
- package/src/__tests__/tool-domain-event-publisher.test.ts +0 -11
- package/src/__tests__/tool-execution-abort-cleanup.test.ts +67 -14
- package/src/__tests__/tool-execution-pipeline.benchmark.test.ts +0 -1
- package/src/__tests__/tool-executor-lifecycle-events.test.ts +3 -6
- package/src/__tests__/tool-executor-shell-integration.test.ts +0 -1
- package/src/__tests__/tool-executor.test.ts +20 -20
- package/src/__tests__/tool-grant-request-escalation.test.ts +8 -9
- package/src/__tests__/tool-metrics-listener.test.ts +0 -9
- package/src/__tests__/tool-notification-listener.test.ts +0 -2
- package/src/__tests__/tool-preview-lifecycle.test.ts +6 -6
- package/src/__tests__/tool-profiling-listener.test.ts +0 -7
- package/src/__tests__/tool-trace-listener.test.ts +0 -11
- package/src/__tests__/trace-emitter.test.ts +1 -1
- package/src/__tests__/trust-context-guards.test.ts +1 -1
- package/src/__tests__/trusted-contact-approval-notifier.test.ts +1 -1
- package/src/__tests__/trusted-contact-inline-approval-integration.test.ts +9 -10
- package/src/__tests__/turn-commit.test.ts +3 -3
- package/src/__tests__/ui-file-upload-surface.test.ts +2 -2
- package/src/__tests__/verification-control-plane-policy.test.ts +0 -1
- package/src/__tests__/voice-scoped-grant-consumer.test.ts +4 -4
- package/src/__tests__/voice-session-bridge.test.ts +31 -31
- package/src/__tests__/workspace-git-service.test.ts +49 -2
- package/src/__tests__/workspace-lifecycle.test.ts +6 -6
- package/src/__tests__/workspace-migration-add-send-diagnostics.test.ts +59 -0
- package/src/__tests__/workspace-migration-avatar-rename.test.ts +128 -0
- package/src/__tests__/workspace-migration-extract-collect-usage-data.test.ts +179 -0
- package/src/__tests__/workspace-migration-seed-device-id.test.ts +328 -0
- package/src/__tests__/workspace-migrations-runner.test.ts +293 -0
- package/src/acp/agent-process.ts +201 -0
- package/src/acp/client-handler.ts +361 -0
- package/src/acp/index.ts +44 -0
- package/src/acp/session-manager.ts +348 -0
- package/src/acp/types.ts +79 -0
- package/src/approvals/AGENTS.md +2 -2
- package/src/approvals/approval-primitive.ts +4 -4
- package/src/approvals/guardian-decision-primitive.ts +7 -7
- package/src/approvals/guardian-request-resolvers.ts +1 -1
- package/src/avatar/ascii-renderer.ts +63 -0
- package/src/avatar/character-components.ts +454 -0
- package/src/avatar/png-renderer.ts +17 -0
- package/src/avatar/svg-compositor.ts +90 -0
- package/src/avatar/traits-png-sync.ts +133 -0
- package/src/calls/call-controller.ts +8 -8
- package/src/calls/call-conversation-messages.ts +1 -1
- package/src/calls/call-domain.ts +4 -4
- package/src/calls/call-pointer-message-composer.ts +2 -2
- package/src/calls/call-pointer-messages.ts +10 -10
- package/src/calls/guardian-action-sweep.ts +3 -3
- package/src/calls/guardian-dispatch.ts +7 -7
- package/src/calls/guardian-question-copy.ts +7 -7
- package/src/calls/relay-server.ts +4 -4
- package/src/calls/twilio-routes.ts +1 -1
- package/src/calls/voice-session-bridge.ts +59 -56
- package/src/cli/AGENTS.md +2 -2
- package/src/cli/commands/avatar.ts +281 -0
- package/src/cli/commands/bash.ts +3 -3
- package/src/cli/commands/channel-verification-sessions.ts +7 -4
- package/src/cli/commands/completions.ts +4 -4
- package/src/cli/commands/config.ts +52 -7
- package/src/cli/commands/{sessions.ts → conversations.ts} +43 -40
- package/src/cli/commands/credential-execution.ts +345 -0
- package/src/cli/commands/credentials.ts +106 -6
- package/src/cli/commands/doctor.ts +9 -3
- package/src/cli/commands/keys.ts +30 -0
- package/src/cli/commands/mcp.ts +2 -2
- package/src/cli/commands/memory.ts +8 -8
- package/src/cli/commands/notifications.ts +2 -2
- package/src/cli/commands/oauth/connections.ts +98 -17
- package/src/cli/commands/oauth/providers.ts +45 -8
- package/src/cli/commands/shotgun.ts +250 -0
- package/src/cli/main-screen.tsx +3 -29
- package/src/cli/program.ts +13 -3
- package/src/cli/reference.ts +4 -2
- package/src/cli.ts +159 -235
- package/src/config/acp-schema.ts +47 -0
- package/src/config/bundled-skills/_shared/CLI_RETRIEVAL_PATTERN.md +14 -12
- package/src/config/bundled-skills/acp/SKILL.md +58 -0
- package/src/config/bundled-skills/acp/TOOLS.json +79 -0
- package/src/config/bundled-skills/{settings/tools/set-avatar.ts → acp/tools/acp-abort.ts} +2 -2
- package/src/config/bundled-skills/acp/tools/acp-spawn.ts +12 -0
- package/src/config/bundled-skills/acp/tools/acp-status.ts +12 -0
- package/src/config/bundled-skills/app-builder/SKILL.md +22 -6
- package/src/config/bundled-skills/browser/SKILL.md +2 -1
- package/src/config/bundled-skills/browser/TOOLS.json +2 -2
- package/src/config/bundled-skills/browser/tools/browser-wait-for-download.ts +1 -1
- package/src/config/bundled-skills/chatgpt-import/SKILL.md +0 -1
- package/src/config/bundled-skills/claude-code/SKILL.md +1 -2
- package/src/config/bundled-skills/claude-code/TOOLS.json +1 -1
- package/src/config/bundled-skills/computer-use/SKILL.md +1 -3
- package/src/config/bundled-skills/contacts/SKILL.md +0 -1
- package/src/config/bundled-skills/contacts/TOOLS.json +4 -0
- package/src/config/bundled-skills/contacts/tools/google-contacts.ts +5 -1
- package/src/config/bundled-skills/followups/SKILL.md +1 -1
- package/src/config/bundled-skills/followups/TOOLS.json +7 -7
- package/src/config/bundled-skills/gmail/SKILL.md +0 -1
- package/src/config/bundled-skills/google-calendar/SKILL.md +0 -1
- package/src/config/bundled-skills/google-calendar/tools/calendar-check-availability.ts +1 -1
- package/src/config/bundled-skills/google-calendar/tools/calendar-create-event.ts +1 -1
- package/src/config/bundled-skills/google-calendar/tools/calendar-get-event.ts +1 -1
- package/src/config/bundled-skills/google-calendar/tools/calendar-list-events.ts +1 -1
- package/src/config/bundled-skills/google-calendar/tools/calendar-rsvp.ts +1 -1
- package/src/config/bundled-skills/google-calendar/tools/shared.ts +1 -5
- package/src/config/bundled-skills/image-studio/SKILL.md +0 -1
- package/src/config/bundled-skills/image-studio/tools/media-generate-image.ts +30 -13
- package/src/config/bundled-skills/media-processing/services/preprocess.ts +5 -1
- package/src/config/bundled-skills/media-processing/tools/analyze-keyframes.ts +3 -3
- package/src/config/bundled-skills/messaging/SKILL.md +11 -13
- package/src/config/bundled-skills/messaging/TOOLS.json +0 -4
- package/src/config/bundled-skills/notifications/SKILL.md +4 -5
- package/src/config/bundled-skills/notifications/TOOLS.json +1 -1
- package/src/config/bundled-skills/notifications/tools/send-notification.ts +2 -2
- package/src/config/bundled-skills/orchestration/SKILL.md +4 -1
- package/src/config/bundled-skills/phone-calls/SKILL.md +20 -8
- package/src/config/bundled-skills/schedule/SKILL.md +1 -1
- package/src/config/bundled-skills/screen-watch/SKILL.md +0 -1
- package/src/config/bundled-skills/sequences/SKILL.md +0 -1
- package/src/config/bundled-skills/sequences/TOOLS.json +4 -4
- package/src/config/bundled-skills/sequences/tools/sequence-create.ts +2 -1
- package/src/config/bundled-skills/sequences/tools/sequence-update.ts +2 -1
- package/src/config/bundled-skills/settings/SKILL.md +2 -3
- package/src/config/bundled-skills/settings/TOOLS.json +0 -22
- package/src/config/bundled-skills/skill-management/SKILL.md +0 -1
- package/src/config/bundled-skills/skill-management/TOOLS.json +0 -8
- package/src/config/bundled-skills/slack/SKILL.md +0 -1
- package/src/config/bundled-skills/subagent/SKILL.md +2 -2
- package/src/config/bundled-skills/subagent/TOOLS.json +2 -2
- package/src/config/bundled-skills/transcribe/tools/transcribe-media.ts +35 -5
- package/src/config/bundled-tool-registry.ts +9 -2
- package/src/config/env.ts +44 -2
- package/src/config/feature-flag-registry.json +161 -25
- package/src/config/loader.ts +3 -0
- package/src/config/raw-config-utils.ts +30 -0
- package/src/config/schema-utils.ts +27 -0
- package/src/config/schema.ts +54 -39
- package/src/config/schemas/calls.ts +219 -152
- package/src/config/schemas/channels.ts +118 -71
- package/src/config/schemas/elevenlabs.ts +39 -24
- package/src/config/schemas/heartbeat.ts +13 -4
- package/src/config/schemas/inference.ts +155 -99
- package/src/config/schemas/ingress.ts +100 -64
- package/src/config/schemas/logging.ts +24 -15
- package/src/config/schemas/mcp.ts +95 -44
- package/src/config/schemas/memory-lifecycle.ts +70 -50
- package/src/config/schemas/memory-processing.ts +46 -25
- package/src/config/schemas/memory-retrieval.ts +206 -139
- package/src/config/schemas/memory-storage.ts +113 -79
- package/src/config/schemas/memory.ts +33 -28
- package/src/config/schemas/notifications.ts +12 -7
- package/src/config/schemas/platform.ts +62 -39
- package/src/config/schemas/sandbox.ts +10 -5
- package/src/config/schemas/security.ts +72 -41
- package/src/config/schemas/services.ts +54 -0
- package/src/config/schemas/skills.ts +131 -81
- package/src/config/schemas/swarm.ts +78 -46
- package/src/config/schemas/timeouts.ts +64 -41
- package/src/config/schemas/workspace-git.ts +219 -162
- package/src/config/skill-state.ts +6 -47
- package/src/config/skills.ts +66 -271
- package/src/config/types.ts +5 -0
- package/src/contacts/contact-store.ts +19 -7
- package/src/contacts/contacts-write.ts +13 -2
- package/src/context/window-manager.ts +1 -1
- package/src/credential-execution/approval-bridge.ts +350 -0
- package/src/credential-execution/client.ts +414 -0
- package/src/credential-execution/executable-discovery.ts +169 -0
- package/src/credential-execution/feature-gates.ts +75 -0
- package/src/credential-execution/managed-catalog.ts +155 -0
- package/src/credential-execution/process-manager.ts +451 -0
- package/src/daemon/approval-generators.ts +13 -7
- package/src/daemon/assistant-attachments.ts +3 -3
- package/src/daemon/config-watcher.ts +23 -15
- package/src/daemon/context-overflow-policy.ts +5 -5
- package/src/daemon/context-overflow-reducer.ts +2 -2
- package/src/daemon/{session-agent-loop-handlers.ts → conversation-agent-loop-handlers.ts} +21 -21
- package/src/daemon/{session-agent-loop.ts → conversation-agent-loop.ts} +93 -72
- package/src/daemon/{session-attachments.ts → conversation-attachments.ts} +35 -9
- package/src/daemon/{session-error.ts → conversation-error.ts} +34 -24
- package/src/daemon/conversation-evictor.ts +204 -0
- package/src/daemon/{session-history.ts → conversation-history.ts} +37 -33
- package/src/daemon/{session-lifecycle.ts → conversation-lifecycle.ts} +16 -16
- package/src/daemon/{session-memory.ts → conversation-memory.ts} +1 -1
- package/src/daemon/{session-messaging.ts → conversation-messaging.ts} +9 -9
- package/src/daemon/{session-notifiers.ts → conversation-notifiers.ts} +25 -25
- package/src/daemon/{session-process.ts → conversation-process.ts} +128 -131
- package/src/daemon/{session-queue-manager.ts → conversation-queue-manager.ts} +11 -8
- package/src/daemon/{session-runtime-assembly.ts → conversation-runtime-assembly.ts} +17 -11
- package/src/daemon/{session-skill-tools.ts → conversation-skill-tools.ts} +18 -18
- package/src/daemon/{session-slash.ts → conversation-slash.ts} +35 -62
- package/src/daemon/{session-surfaces.ts → conversation-surfaces.ts} +34 -34
- package/src/daemon/{session-tool-setup.ts → conversation-tool-setup.ts} +41 -36
- package/src/daemon/{session-usage.ts → conversation-usage.ts} +1 -1
- package/src/daemon/{session-workspace.ts → conversation-workspace.ts} +3 -3
- package/src/daemon/{session.ts → conversation.ts} +96 -73
- package/src/daemon/doordash-steps.ts +9 -8
- package/src/daemon/guardian-action-generators.ts +8 -2
- package/src/daemon/handlers/config-channels.ts +7 -4
- package/src/daemon/handlers/config-model.ts +33 -32
- package/src/daemon/handlers/config-slack-channel.ts +28 -6
- package/src/daemon/handlers/config-voice.ts +1 -2
- package/src/daemon/handlers/{session-history.ts → conversation-history.ts} +4 -4
- package/src/daemon/handlers/{sessions.ts → conversations.ts} +163 -183
- package/src/daemon/handlers/recording.ts +20 -20
- package/src/daemon/handlers/shared.ts +17 -17
- package/src/daemon/handlers/skills.ts +164 -21
- package/src/daemon/history-repair.ts +1 -1
- package/src/daemon/host-bash-proxy.ts +11 -3
- package/src/daemon/host-cu-proxy.ts +2 -2
- package/src/daemon/host-file-proxy.ts +3 -3
- package/src/daemon/lifecycle.ts +103 -78
- package/src/daemon/main.ts +4 -0
- package/src/daemon/media-visibility-policy.ts +10 -10
- package/src/daemon/message-protocol.ts +11 -8
- package/src/daemon/message-types/acp.ts +66 -0
- package/src/daemon/message-types/computer-use.ts +4 -4
- package/src/daemon/message-types/{sessions.ts → conversations.ts} +74 -80
- package/src/daemon/message-types/documents.ts +2 -2
- package/src/daemon/message-types/host-bash.ts +3 -1
- package/src/daemon/message-types/host-cu.ts +1 -1
- package/src/daemon/message-types/host-file.ts +3 -3
- package/src/daemon/message-types/integrations.ts +2 -2
- package/src/daemon/message-types/messages.ts +23 -23
- package/src/daemon/message-types/notifications.ts +5 -5
- package/src/daemon/message-types/settings.ts +1 -1
- package/src/daemon/message-types/shared.ts +5 -3
- package/src/daemon/message-types/skills.ts +1 -10
- package/src/daemon/message-types/subagents.ts +2 -2
- package/src/daemon/message-types/surfaces.ts +7 -7
- package/src/daemon/message-types/work-items.ts +4 -4
- package/src/daemon/parse-actual-tokens-from-error.test.ts +3 -7
- package/src/daemon/providers-setup.ts +79 -0
- package/src/daemon/seed-files.ts +7 -26
- package/src/daemon/server.ts +451 -209
- package/src/daemon/startup-error.ts +126 -0
- package/src/daemon/tool-side-effects.ts +2 -18
- package/src/daemon/trace-emitter.ts +3 -3
- package/src/daemon/verification-session-intent.ts +1 -1
- package/src/daemon/watch-handler.ts +23 -21
- package/src/email/feature-gate.ts +23 -0
- package/src/events/domain-events.ts +2 -8
- package/src/events/tool-domain-event-publisher.ts +0 -8
- package/src/events/tool-metrics-listener.ts +0 -7
- package/src/export/formatter.ts +1 -1
- package/src/followups/followup-store.ts +8 -5
- package/src/followups/types.ts +2 -2
- package/src/heartbeat/heartbeat-service.ts +1 -1
- package/src/hooks/discovery.ts +3 -0
- package/src/hooks/manager.ts +27 -2
- package/src/hooks/types.ts +4 -1
- package/src/inbound/platform-callback-registration.ts +24 -2
- package/src/instrument.ts +37 -19
- package/src/media/app-icon-generator.ts +3 -3
- package/src/media/avatar-router.ts +3 -3
- package/src/memory/app-git-service.ts +3 -3
- package/src/memory/attachments-store.ts +92 -27
- package/src/memory/canonical-guardian-store.ts +37 -27
- package/src/memory/channel-verification-sessions.ts +6 -6
- package/src/memory/checkpoints.ts +5 -0
- package/src/memory/conversation-bootstrap.ts +2 -2
- package/src/memory/conversation-crud.ts +147 -22
- package/src/memory/conversation-key-store.ts +40 -4
- package/src/memory/conversation-queries.ts +8 -6
- package/src/memory/db-init.ts +46 -2
- package/src/memory/embedding-backend.ts +71 -11
- package/src/memory/external-conversation-store.ts +1 -1
- package/src/memory/guardian-action-store.ts +3 -3
- package/src/memory/indexer.ts +20 -9
- package/src/memory/invite-store.ts +4 -4
- package/src/memory/items-extractor.ts +48 -4
- package/src/memory/job-handlers/backfill.ts +15 -8
- package/src/memory/job-handlers/capability-cards.ts +420 -0
- package/src/memory/job-handlers/cleanup.ts +1 -1
- package/src/memory/job-handlers/thread-starters.ts +348 -0
- package/src/memory/jobs-store.ts +4 -7
- package/src/memory/jobs-worker.ts +8 -0
- package/src/memory/migrations/033-scoped-approval-grants.ts +4 -4
- package/src/memory/migrations/102-alter-table-columns.ts +5 -0
- package/src/memory/migrations/105-contacts-and-triage.ts +3 -3
- package/src/memory/migrations/111-media-assets.ts +1 -106
- package/src/memory/migrations/121-canonical-guardian-requests.ts +5 -5
- package/src/memory/migrations/159-drop-contact-interaction-columns.ts +5 -0
- package/src/memory/migrations/161-drop-orphaned-media-tables.ts +18 -0
- package/src/memory/migrations/162-guardian-timestamps-epoch-ms.ts +283 -0
- package/src/memory/migrations/163-rename-notification-thread-columns.ts +35 -0
- package/src/memory/migrations/164-rename-conversation-type-column.ts +19 -0
- package/src/memory/migrations/165-rename-inbox-thread-state-table.ts +15 -0
- package/src/memory/migrations/166-rename-followups-thread-id.ts +20 -0
- package/src/memory/migrations/167-rename-sequence-enrollments-thread-id.ts +20 -0
- package/src/memory/migrations/168-rename-sequence-steps-reply-key.ts +17 -0
- package/src/memory/migrations/169-rename-gmail-provider-key-to-google.ts +64 -0
- package/src/memory/migrations/170-thread-starters-table.ts +32 -0
- package/src/memory/migrations/171-capability-card-columns.ts +43 -0
- package/src/memory/migrations/index.ts +11 -0
- package/src/memory/migrations/registry.ts +19 -0
- package/src/memory/schema/calls.ts +1 -1
- package/src/memory/schema/contacts.ts +3 -3
- package/src/memory/schema/conversations.ts +2 -2
- package/src/memory/schema/guardian.ts +9 -9
- package/src/memory/schema/memory-core.ts +37 -0
- package/src/memory/schema/notifications.ts +4 -4
- package/src/memory/schema/tasks.ts +1 -1
- package/src/memory/scoped-approval-grants.ts +14 -14
- package/src/memory/search/types.ts +3 -3
- package/src/memory/thread-starters-cadence.ts +107 -0
- package/src/memory/turn-events-store.ts +48 -0
- package/src/messaging/providers/telegram-bot/adapter.ts +1 -1
- package/src/notifications/AGENTS.md +1 -1
- package/src/notifications/README.md +103 -103
- package/src/notifications/adapters/slack.ts +3 -3
- package/src/notifications/adapters/telegram.ts +3 -3
- package/src/notifications/broadcaster.ts +40 -40
- package/src/notifications/{thread-candidates.ts → conversation-candidates.ts} +18 -18
- package/src/notifications/conversation-pairing.ts +35 -31
- package/src/notifications/{thread-seed-composer.ts → conversation-seed-composer.ts} +9 -9
- package/src/notifications/decision-engine.ts +105 -82
- package/src/notifications/deliveries-store.ts +14 -14
- package/src/notifications/emit-signal.ts +13 -13
- package/src/notifications/signal.ts +2 -2
- package/src/notifications/types.ts +16 -12
- package/src/oauth/byo-connection.test.ts +1 -1
- package/src/oauth/oauth-store.ts +37 -15
- package/src/oauth/platform-connection.test.ts +2 -2
- package/src/oauth/provider-behaviors.ts +2 -1
- package/src/oauth/seed-providers.ts +3 -11
- package/src/oauth/token-persistence.ts +41 -25
- package/src/outbound-proxy/index.ts +27 -3
- package/src/permissions/checker.ts +15 -2
- package/src/permissions/prompter.ts +3 -3
- package/src/permissions/secret-prompter.ts +2 -2
- package/src/permissions/types.ts +2 -2
- package/src/prompts/__tests__/build-cli-reference-section.test.ts +60 -9
- package/src/prompts/system-prompt.ts +173 -232
- package/src/prompts/templates/UPDATES.md +0 -12
- package/src/prompts/update-bulletin-format.ts +16 -0
- package/src/prompts/update-bulletin.ts +18 -6
- package/src/providers/anthropic/client.ts +135 -11
- package/src/providers/managed-proxy/context.ts +26 -0
- package/src/providers/provider-availability.ts +39 -0
- package/src/providers/provider-send-message.ts +20 -6
- package/src/providers/registry.ts +121 -82
- package/src/runtime/AGENTS.md +5 -5
- package/src/runtime/access-request-helper.ts +2 -2
- package/src/runtime/actor-trust-resolver.ts +2 -2
- package/src/runtime/approval-conversation-turn.ts +2 -2
- package/src/runtime/assistant-event-hub.ts +9 -9
- package/src/runtime/assistant-event.ts +5 -5
- package/src/runtime/auth/__tests__/context.test.ts +2 -2
- package/src/runtime/auth/__tests__/external-assistant-id.test.ts +88 -0
- package/src/runtime/auth/__tests__/guard-tests.test.ts +1 -5
- package/src/runtime/auth/__tests__/local-auth-context.test.ts +4 -4
- package/src/runtime/auth/__tests__/middleware.test.ts +2 -2
- package/src/runtime/auth/__tests__/subject.test.ts +6 -6
- package/src/runtime/auth/context.ts +1 -1
- package/src/runtime/auth/credential-service.ts +1 -1
- package/src/runtime/auth/external-assistant-id.ts +36 -17
- package/src/runtime/auth/route-policy.ts +17 -0
- package/src/runtime/auth/subject.ts +7 -7
- package/src/runtime/auth/types.ts +1 -1
- package/src/runtime/channel-approval-types.ts +1 -1
- package/src/runtime/channel-approvals.ts +9 -6
- package/src/runtime/channel-invite-transport.ts +10 -7
- package/src/runtime/channel-readiness-service.ts +5 -2
- package/src/runtime/channel-retry-sweep.ts +1 -1
- package/src/runtime/channel-verification-service.ts +2 -2
- package/src/runtime/confirmation-request-guardian-bridge.ts +3 -3
- package/src/runtime/{session-approval-overrides.ts → conversation-approval-overrides.ts} +6 -6
- package/src/runtime/guardian-action-grant-minter.ts +2 -4
- package/src/runtime/guardian-action-service.ts +2 -2
- package/src/runtime/guardian-decision-types.ts +13 -8
- package/src/runtime/guardian-reply-router.ts +4 -4
- package/src/runtime/http-server.ts +70 -33
- package/src/runtime/http-types.ts +19 -15
- package/src/runtime/invite-redemption-service.ts +8 -3
- package/src/runtime/local-actor-identity.ts +9 -7
- package/src/runtime/pending-interactions.ts +8 -8
- package/src/runtime/routes/acp-routes.ts +170 -0
- package/src/runtime/routes/approval-routes.ts +3 -3
- package/src/runtime/routes/approval-strategies/guardian-callback-strategy.ts +1 -1
- package/src/runtime/routes/attachment-routes.ts +2 -2
- package/src/runtime/routes/avatar-routes.ts +83 -0
- package/src/runtime/routes/btw-routes.ts +27 -13
- package/src/runtime/routes/canonical-guardian-expiry-sweep.ts +1 -1
- package/src/runtime/routes/channel-route-shared.ts +5 -3
- package/src/runtime/routes/channel-verification-routes.ts +3 -3
- package/src/runtime/routes/{session-management-routes.ts → conversation-management-routes.ts} +82 -28
- package/src/runtime/routes/{session-query-routes.ts → conversation-query-routes.ts} +22 -19
- package/src/runtime/routes/conversation-routes.ts +147 -164
- package/src/runtime/routes/debug-routes.ts +8 -2
- package/src/runtime/routes/diagnostics-routes.ts +16 -17
- package/src/runtime/routes/events-routes.ts +1 -1
- package/src/runtime/routes/guardian-action-routes.ts +4 -4
- package/src/runtime/routes/guardian-approval-interception.ts +1 -1
- package/src/runtime/routes/host-bash-routes.ts +1 -1
- package/src/runtime/routes/host-cu-routes.ts +1 -1
- package/src/runtime/routes/host-file-routes.ts +1 -1
- package/src/runtime/routes/inbound-message-handler.ts +1 -1
- package/src/runtime/routes/inbound-stages/background-dispatch.ts +1 -1
- package/src/runtime/routes/inbound-stages/escalation-intercept.ts +1 -1
- package/src/runtime/routes/inbound-stages/secret-ingress-check.ts +1 -1
- package/src/runtime/routes/log-export-routes.ts +360 -40
- package/src/runtime/routes/recording-routes.ts +5 -5
- package/src/runtime/routes/schedule-routes.ts +13 -7
- package/src/runtime/routes/secret-routes.ts +178 -18
- package/src/runtime/routes/settings-routes.ts +23 -10
- package/src/runtime/routes/skills-routes.ts +38 -0
- package/src/runtime/routes/subagents-routes.ts +10 -10
- package/src/runtime/routes/surface-action-routes.ts +45 -45
- package/src/runtime/routes/surface-content-routes.ts +18 -18
- package/src/runtime/routes/thread-starter-routes.ts +294 -0
- package/src/runtime/routes/watch-routes.ts +6 -6
- package/src/runtime/routes/work-items-routes.test.ts +109 -0
- package/src/runtime/routes/work-items-routes.ts +47 -46
- package/src/runtime/tool-grant-request-helper.ts +3 -3
- package/src/runtime/trust-context-resolver.ts +1 -1
- package/src/schedule/scheduler.ts +14 -12
- package/src/security/credential-backend.ts +29 -5
- package/src/security/encrypted-store.ts +64 -5
- package/src/security/keychain-broker-client.ts +45 -12
- package/src/security/secure-keys.ts +46 -0
- package/src/security/token-manager.ts +67 -167
- package/src/sequence/engine.ts +12 -11
- package/src/sequence/reply-matcher.ts +16 -13
- package/src/sequence/store.ts +10 -7
- package/src/sequence/types.ts +2 -2
- package/src/signals/bash.ts +4 -4
- package/src/signals/cancel.ts +14 -17
- package/src/signals/confirm.ts +4 -7
- package/src/signals/conversation-undo.ts +16 -20
- package/src/signals/event-stream.ts +187 -0
- package/src/signals/shotgun.ts +200 -0
- package/src/signals/trust-rule.ts +3 -6
- package/src/signals/user-message.ts +146 -0
- package/src/skills/catalog-install.ts +1 -1
- package/src/skills/managed-store.ts +0 -13
- package/src/subagent/manager.ts +82 -71
- package/src/subagent/types.ts +5 -5
- package/src/swarm/backend-claude-code.ts +1 -1
- package/src/tasks/SPEC.md +5 -5
- package/src/tasks/task-runner.ts +1 -1
- package/src/telemetry/types.ts +26 -0
- package/src/telemetry/usage-telemetry-reporter.test.ts +145 -24
- package/src/telemetry/usage-telemetry-reporter.ts +79 -42
- package/src/tools/AGENTS.md +26 -0
- package/src/tools/acp/abort.ts +32 -0
- package/src/tools/acp/spawn.ts +70 -0
- package/src/tools/acp/status.ts +31 -0
- package/src/tools/assets/materialize.ts +34 -19
- package/src/tools/assets/search.ts +13 -13
- package/src/tools/browser/browser-execution.ts +63 -33
- package/src/tools/browser/browser-handoff.ts +12 -9
- package/src/tools/browser/browser-manager.ts +88 -78
- package/src/tools/browser/browser-screencast.ts +30 -28
- package/src/tools/calls/call-start.ts +1 -1
- package/src/tools/calls/call-status.ts +1 -1
- package/src/tools/claude-code/claude-code.ts +9 -9
- package/src/tools/credential-execution/make-authenticated-request.ts +198 -0
- package/src/tools/credential-execution/manage-secure-command-tool.ts +372 -0
- package/src/tools/credential-execution/run-authenticated-command.ts +261 -0
- package/src/tools/credentials/broker.ts +1 -1
- package/src/tools/credentials/metadata-store.ts +46 -227
- package/src/tools/credentials/resolve.ts +2 -1
- package/src/tools/document/document-tool.ts +3 -3
- package/src/tools/executor.ts +144 -9
- package/src/tools/followups/followup_create.ts +8 -7
- package/src/tools/followups/followup_list.ts +3 -1
- package/src/tools/followups/followup_resolve.ts +8 -7
- package/src/tools/host-filesystem/edit.ts +1 -1
- package/src/tools/host-filesystem/read.ts +1 -1
- package/src/tools/host-filesystem/write.ts +1 -1
- package/src/tools/host-terminal/host-shell.ts +54 -7
- package/src/tools/memory/definitions.ts +1 -1
- package/src/tools/memory/handlers.ts +1 -1
- package/src/tools/network/script-proxy/session-manager.ts +290 -515
- package/src/tools/network/web-fetch.ts +1 -1
- package/src/tools/network/web-search.ts +4 -4
- package/src/tools/permission-checker.ts +38 -23
- package/src/tools/registry.ts +14 -2
- package/src/tools/secret-detection-handler.ts +3 -8
- package/src/tools/side-effects.ts +2 -1
- package/src/tools/skills/load.ts +15 -1
- package/src/tools/skills/sandbox-runner.ts +0 -1
- package/src/tools/skills/scaffold-managed.ts +0 -8
- package/src/tools/subagent/abort.ts +1 -1
- package/src/tools/subagent/message.ts +2 -2
- package/src/tools/subagent/read.ts +2 -2
- package/src/tools/subagent/spawn.ts +1 -1
- package/src/tools/subagent/status.ts +10 -4
- package/src/tools/swarm/delegate.ts +12 -12
- package/src/tools/system/avatar-generator.ts +52 -79
- package/src/tools/terminal/backends/native.ts +48 -8
- package/src/tools/terminal/backends/types.ts +7 -0
- package/src/tools/terminal/safe-env.ts +4 -1
- package/src/tools/terminal/shell.ts +106 -2
- package/src/tools/tool-approval-handler.ts +2 -17
- package/src/tools/tool-manifest.ts +43 -0
- package/src/tools/types.ts +28 -5
- package/src/tools/watch/screen-watch.ts +6 -6
- package/src/tools/watch/watch-state.ts +33 -26
- package/src/util/clipboard.ts +1 -1
- package/src/util/device-id.ts +101 -0
- package/src/util/platform.ts +10 -0
- package/src/util/silently.ts +7 -8
- package/src/watcher/engine.ts +1 -1
- package/src/work-items/resolve-required-tools.test.ts +37 -0
- package/src/work-items/resolve-required-tools.ts +26 -0
- package/src/work-items/work-item-runner.ts +29 -27
- package/src/workspace/commit-message-enrichment-service.ts +1 -1
- package/src/workspace/commit-message-provider.ts +2 -2
- package/src/workspace/git-service.ts +27 -14
- package/src/workspace/migrations/001-avatar-rename.ts +25 -0
- package/src/workspace/migrations/002-backfill-installation-id.ts +75 -0
- package/src/workspace/migrations/003-seed-device-id.ts +101 -0
- package/src/workspace/migrations/004-extract-collect-usage-data.ts +50 -0
- package/src/workspace/migrations/005-add-send-diagnostics.ts +12 -0
- package/src/workspace/migrations/006-services-config.ts +132 -0
- package/src/workspace/migrations/registry.ts +20 -0
- package/src/workspace/migrations/runner.ts +117 -0
- package/src/workspace/migrations/types.ts +11 -0
- package/src/workspace/provider-commit-message-generator.ts +7 -4
- package/src/workspace/turn-commit.ts +13 -13
- package/tsconfig.json +0 -1
- package/src/__tests__/handlers-task-submit-slash.test.ts +0 -39
- package/src/__tests__/session-slash-known.test.ts +0 -477
- package/src/__tests__/slash-commands-catalog.test.ts +0 -94
- package/src/__tests__/slash-commands-parser.test.ts +0 -127
- package/src/__tests__/slash-commands-resolver.test.ts +0 -231
- package/src/__tests__/slash-commands-rewrite.test.ts +0 -40
- package/src/cli/http-client.ts +0 -76
- package/src/daemon/install-cli-launchers.ts +0 -170
- package/src/daemon/session-evictor.ts +0 -203
- package/src/skills/slash-commands.ts +0 -203
- /package/src/__tests__/{script-proxy-session-runtime.test.ts → script-proxy-conversation-runtime.test.ts} +0 -0
- /package/src/daemon/{session-media-retry.ts → conversation-media-retry.ts} +0 -0
|
@@ -0,0 +1,411 @@
|
|
|
1
|
+
# Credential Execution Service (CES) — Architecture Decision Record
|
|
2
|
+
|
|
3
|
+
## Status
|
|
4
|
+
|
|
5
|
+
**Accepted** — locked decisions below are final for the initial implementation.
|
|
6
|
+
|
|
7
|
+
## Context
|
|
8
|
+
|
|
9
|
+
Untrusted agents (managed assistants, delegated workers, third-party skill invocations) need to execute credential-bearing operations (API calls, CLI commands, browser automation with stored secrets) without the agent ever observing plaintext secret material. The existing credential broker (`assistant/src/tools/credentials/broker.ts`) operates inside the assistant process, which means the assistant runtime has theoretical access to secret values during brokered use. For local single-user deployments this is acceptable, but for managed multi-tenant and untrusted-agent scenarios, a stronger isolation boundary is required.
|
|
10
|
+
|
|
11
|
+
## Decision
|
|
12
|
+
|
|
13
|
+
Introduce the **Credential Execution Service (CES)** as a hard-boundary sidecar that is the only trusted component allowed to materialize credentials for execution.
|
|
14
|
+
|
|
15
|
+
### Core Design Principles
|
|
16
|
+
|
|
17
|
+
1. **Separate package**: CES lives in a new top-level `credential-executor/` package in the monorepo. There are **no direct source imports from `assistant/` to `credential-executor/` or vice versa.** Communication is exclusively via RPC (see transports below).
|
|
18
|
+
|
|
19
|
+
2. **Separate managed image**: In managed deployments, CES runs as its own container image, distinct from the assistant runtime image and the gateway image. This means managed rollout requires a **third runtime image** and corresponding `vembda` pod-template changes.
|
|
20
|
+
|
|
21
|
+
3. **CES-owned durable state**: Grants (which credentials are authorized for use, under what constraints) and audit logs (which credentials were materialized, when, by whom, for what purpose) are **CES-owned durable state**. The assistant does not read or write grant tables directly. Grant lifecycle is managed entirely through CES RPC.
|
|
22
|
+
|
|
23
|
+
4. **Assistant-to-CES RPC only**: The assistant sends execution requests to CES; CES materializes the credential, executes the operation in its own sandbox, and returns the result (stdout/stderr/exit code, HTTP response body, etc.) to the assistant. The assistant never sees the plaintext credential value.
|
|
24
|
+
|
|
25
|
+
## Transports
|
|
26
|
+
|
|
27
|
+
CES supports two transport modes, selected based on deployment topology:
|
|
28
|
+
|
|
29
|
+
### Local child-process transport (stdio)
|
|
30
|
+
|
|
31
|
+
For local single-user and development deployments, the assistant spawns CES as a child process and communicates over stdin/stdout using newline-delimited JSON-RPC. The assistant is responsible for the CES process lifecycle (start, health check, restart, shutdown).
|
|
32
|
+
|
|
33
|
+
### Managed sidecar transport (Unix socket)
|
|
34
|
+
|
|
35
|
+
For managed multi-tenant deployments, CES runs as a sidecar container in the same pod. Communication occurs over a **bootstrap Unix socket** mounted at a well-known path in a shared `emptyDir` volume. The sidecar starts independently and the assistant connects to the socket on startup.
|
|
36
|
+
|
|
37
|
+
## CES Tools
|
|
38
|
+
|
|
39
|
+
CES exposes exactly three tools to the assistant, registered as a **deliberate exception** to the skill-first tool direction (see `AGENTS.md` and `assistant/src/tools/AGENTS.md`). These tools are not skills because they require hard process-boundary isolation that skill scripts cannot provide.
|
|
40
|
+
|
|
41
|
+
| Tool | Purpose |
|
|
42
|
+
| ---------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
43
|
+
| `run_authenticated_command` | Execute a shell command with credential environment variables injected by CES. The credential values are set in the CES process environment only — never transmitted to the assistant. |
|
|
44
|
+
| `make_authenticated_request` | Execute an HTTP request with credential-bearing headers/auth injected by CES. CES performs the HTTP call and returns the response body and status to the assistant. |
|
|
45
|
+
| `manage_secure_command_tool` | Register and manage secure command tool bundles in the CES toolstore. Handles bundle lifecycle (registration, unregistration) for manifest-driven credential-bearing commands. |
|
|
46
|
+
|
|
47
|
+
### Tool registration
|
|
48
|
+
|
|
49
|
+
CES tools use the standard `class ... implements Tool` registration pattern. This is explicitly approved as a deliberate exception to the no-new-tools policy because:
|
|
50
|
+
|
|
51
|
+
- The security boundary requires that credential materialization happens in a separate process
|
|
52
|
+
- Skill scripts run inside the assistant process and cannot enforce the hard isolation invariant
|
|
53
|
+
- The tools are thin RPC stubs; the actual logic lives in the `credential-executor/` package
|
|
54
|
+
|
|
55
|
+
## Locked Decisions
|
|
56
|
+
|
|
57
|
+
### 1. `host_bash` is outside the strong secrecy guarantee
|
|
58
|
+
|
|
59
|
+
The existing `host_bash` tool executes commands on the host machine without any credential isolation. When an agent uses `host_bash`, it has full access to the host environment, including any credentials stored in environment variables, config files, or keychains accessible to the user. CES does not attempt to intercept or sandbox `host_bash` invocations.
|
|
60
|
+
|
|
61
|
+
**Implication**: `host_bash` represents a weaker security tier. Agents that require the strong secrecy guarantee must use `run_authenticated_command` instead. Trust rules and permission policies should reflect this distinction — managed deployments may deny `host_bash` entirely for untrusted agents while allowing `run_authenticated_command`.
|
|
62
|
+
|
|
63
|
+
### 2. Local static secrets are local-mode only — by design
|
|
64
|
+
|
|
65
|
+
For the initial implementation, local static secrets (API keys, tokens stored via the credential store in `~/.vellum/protected/`) are only accessible to CES in **local mode**, where CES runs as a child process of the assistant as the same OS user. CES reads them at materialization time via direct filesystem access.
|
|
66
|
+
|
|
67
|
+
In **managed mode**, `local_static` handles are not supported and the CES returns a clear error for any `local_static` handle. Managed deployments use `platform_oauth` handles exclusively. This is a deliberate architectural decision, not a temporary limitation.
|
|
68
|
+
|
|
69
|
+
#### Why `local_static` cannot work in managed mode
|
|
70
|
+
|
|
71
|
+
The original design considered having managed deployments share static secrets via the assistant data volume. This is technically impossible due to how the encrypted key store works.
|
|
72
|
+
|
|
73
|
+
The `local-secure-key-backend.ts` module uses PBKDF2 key derivation where the encryption key is derived from `userInfo().username` and `userInfo().homedir`. In managed deployments:
|
|
74
|
+
|
|
75
|
+
- The **assistant container** runs as `root` (homedir `/root`)
|
|
76
|
+
- The **CES sidecar container** runs as `ces` / uid 1001 (homedir `/home/ces`)
|
|
77
|
+
|
|
78
|
+
These produce different PBKDF2-derived AES keys. Even if the encrypted key store file (`keys.enc`) were mounted as a shared volume, CES would derive a different decryption key and silently fail to decrypt the secrets.
|
|
79
|
+
|
|
80
|
+
#### Rejected alternatives
|
|
81
|
+
|
|
82
|
+
Three alternatives were evaluated and rejected because each breaks a core security invariant:
|
|
83
|
+
|
|
84
|
+
1. **Mount decrypted secrets into the CES container** — This would require decrypting secrets in the assistant container and writing plaintext to a shared volume, breaking the "secrets never in assistant process memory" boundary (Boundary Invariant #2).
|
|
85
|
+
|
|
86
|
+
2. **Use shared key derivation independent of UID** — Deriving the encryption key from a shared secret (e.g., a pod-level token) rather than per-user identity would weaken the encrypted-at-rest security model. The UID-based derivation ensures that only the user who stored the credential can decrypt it, which is a fundamental property of the local credential store.
|
|
87
|
+
|
|
88
|
+
3. **Pre-decrypt and pass via the RPC socket** — Having the assistant decrypt the secret and send it to CES over the Unix socket would mean the assistant process handles plaintext credential values, directly violating the CES process-boundary isolation guarantee.
|
|
89
|
+
|
|
90
|
+
Since all alternatives break security invariants that CES exists to enforce, managed deployments route credential access through `platform_oauth` where the platform manages token lifecycle and CES requests materialized tokens via the platform proxy endpoint.
|
|
91
|
+
|
|
92
|
+
Future iterations may move secret storage to a dedicated secret manager (e.g., cloud KMS, Vault) with CES as the only authorized reader, which would enable static secrets in managed mode without compromising the process-boundary isolation.
|
|
93
|
+
|
|
94
|
+
### 3. Platform OAuth materialization stays on the platform
|
|
95
|
+
|
|
96
|
+
OAuth tokens managed by the platform (`vellum-assistant-platform`) — including token refresh, revocation, and scope management — continue to be handled by the platform's token management system. CES does not duplicate OAuth lifecycle management. When CES needs an OAuth token, it requests a materialized token from the platform via the existing platform proxy endpoint, using the same mechanism the assistant currently uses.
|
|
97
|
+
|
|
98
|
+
### 4. Secure generic authenticated HTTP must not run through `run_authenticated_command`
|
|
99
|
+
|
|
100
|
+
The existing `run_authenticated_command` pattern (used by the script proxy for credentialed bash commands) must not be used as the transport for generic authenticated HTTP requests. `make_authenticated_request` is a purpose-built tool that:
|
|
101
|
+
|
|
102
|
+
- Validates the target URL against the credential's allowed-domains policy before materializing
|
|
103
|
+
- Does not expose a shell execution surface (no command injection vector)
|
|
104
|
+
- Returns only the HTTP response body and status, not raw shell output
|
|
105
|
+
- Produces a structured audit log entry with URL, method, and credential ID (not raw command text)
|
|
106
|
+
|
|
107
|
+
Routing HTTP requests through shell commands (`curl` with credential env vars via `run_authenticated_command`) would bypass domain validation and produce inferior audit trails.
|
|
108
|
+
|
|
109
|
+
## Grant Persistence
|
|
110
|
+
|
|
111
|
+
CES manages its own grant table, separate from the assistant's `scoped_approval_grants` table. CES grants answer: "Is credential X authorized for purpose Y?" rather than "Did a guardian approve this specific tool invocation?"
|
|
112
|
+
|
|
113
|
+
CES has two grant tiers:
|
|
114
|
+
|
|
115
|
+
- **Persistent grants** (`always_allow`): Stored in the CES grant table and scoped to the entire assistant — not to a specific session. These are analogous to trust rules: once a user approves `always_allow` for a credential+purpose pair, any session on that assistant can use the grant. The `session_id` field on persistent grants records which session created the grant (audit metadata), but is not used as an enforcement filter during grant matching.
|
|
116
|
+
|
|
117
|
+
- **Temporary grants** (`allow_once`, `allow_10m`, `allow_conversation`): Held in-memory by the CES process and scoped to the session or conversation that created them. These grants are not persisted and do not survive CES restarts. `allow_once` is consumed immediately after a single use; `allow_10m` expires after 10 minutes; `allow_conversation` is scoped to the originating conversation via key matching but remains in memory until the CES process restarts (there is no automatic cleanup on conversation end).
|
|
118
|
+
|
|
119
|
+
### Persistent grant table
|
|
120
|
+
|
|
121
|
+
| Field | Purpose |
|
|
122
|
+
| ------------------ | ------------------------------------------------------------------------------------- |
|
|
123
|
+
| `grant_id` | Unique identifier |
|
|
124
|
+
| `session_id` | The agent session that created this grant (audit metadata, not an enforcement filter) |
|
|
125
|
+
| `credential_id` | Which credential is authorized |
|
|
126
|
+
| `allowed_purposes` | Constrained set of purposes (e.g., specific API endpoints, specific tools) |
|
|
127
|
+
| `created_at` | When the grant was minted |
|
|
128
|
+
| `expires_at` | TTL-based expiry |
|
|
129
|
+
| `consumed_at` | When the grant was used (null if unused) |
|
|
130
|
+
| `revoked_at` | When the grant was revoked (null if active) |
|
|
131
|
+
|
|
132
|
+
Audit logs record every materialization event with: grant ID, credential ID, tool name, target (URL/command/form field), timestamp, and outcome (success/failure).
|
|
133
|
+
|
|
134
|
+
## Deployment Topology
|
|
135
|
+
|
|
136
|
+
### Local
|
|
137
|
+
|
|
138
|
+
```
|
|
139
|
+
┌─────────────────────────────────────┐
|
|
140
|
+
│ assistant (Bun) │
|
|
141
|
+
│ ├── spawns CES as child process │
|
|
142
|
+
│ └── communicates via stdio JSON-RPC│
|
|
143
|
+
│ │ │
|
|
144
|
+
│ ▼ │
|
|
145
|
+
│ credential-executor (Bun) │
|
|
146
|
+
│ ├── reads secrets from filesystem │
|
|
147
|
+
│ ├── executes credentialed commands │
|
|
148
|
+
│ └── owns grant + audit tables │
|
|
149
|
+
└─────────────────────────────────────┘
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
### Managed (pod)
|
|
153
|
+
|
|
154
|
+
```
|
|
155
|
+
┌─────────────────────────────────────────┐
|
|
156
|
+
│ Pod │
|
|
157
|
+
│ ┌──────────────┐ ┌─────────────────┐ │
|
|
158
|
+
│ │ assistant │ │ CES sidecar │ │
|
|
159
|
+
│ │ container │ │ container │ │
|
|
160
|
+
│ │ ◄──► (own image) │ │
|
|
161
|
+
│ │ (Unix sock) │ │ │ │
|
|
162
|
+
│ └──────────────┘ └─────────────────┘ │
|
|
163
|
+
│ │ │ │
|
|
164
|
+
│ ▼ ▼ │
|
|
165
|
+
│ ┌─────────────────────────────────┐ │
|
|
166
|
+
│ │ shared emptyDir volume │ │
|
|
167
|
+
│ │ └── /run/ces-bootstrap/ces.sock │ │
|
|
168
|
+
│ └─────────────────────────────────┘ │
|
|
169
|
+
│ │ │
|
|
170
|
+
│ ▼ │
|
|
171
|
+
│ ┌─────────────────────────────────┐ │
|
|
172
|
+
│ │ assistant data volume (RO) │ │
|
|
173
|
+
│ │ └── secrets (read-only mount) │ │
|
|
174
|
+
│ └─────────────────────────────────┘ │
|
|
175
|
+
└─────────────────────────────────────────┘
|
|
176
|
+
```
|
|
177
|
+
|
|
178
|
+
## Shared Private Packages
|
|
179
|
+
|
|
180
|
+
CES and the assistant share contract definitions and credential-storage abstractions through three private packages in `packages/`:
|
|
181
|
+
|
|
182
|
+
| Package | Purpose | Consumers |
|
|
183
|
+
| ------------------------------ | ------------------------------------------------------------------------------------------------------------------------- | ------------------------------------ |
|
|
184
|
+
| `@vellumai/ces-contracts` | RPC protocol types, method names, protocol version constant, grant shapes, credential handle types, and rendering helpers | `assistant/`, `credential-executor/` |
|
|
185
|
+
| `@vellumai/credential-storage` | Credential store read API (static secrets and OAuth runtime), unified credential handle abstraction | `assistant/`, `credential-executor/` |
|
|
186
|
+
| `@vellumai/egress-proxy` | Session-scoped egress proxy lifecycle (create, start, stop, env-var injection) | `assistant/`, `credential-executor/` |
|
|
187
|
+
|
|
188
|
+
These packages are the **only** allowed shared-code path between the assistant and CES. Direct source imports between `assistant/` and `credential-executor/` remain banned. The packages are built locally via `workspace:*` references and copied into the CES Docker image at build time (`COPY packages/ ...` in `credential-executor/Dockerfile`).
|
|
189
|
+
|
|
190
|
+
## Secure Command Auth Adapters
|
|
191
|
+
|
|
192
|
+
CES materializes credentials into the command execution environment through pluggable auth adapters. Each adapter type has different security properties:
|
|
193
|
+
|
|
194
|
+
| Adapter | Mechanism | Cleanup | Example |
|
|
195
|
+
| -------------------- | ---------------------------------------------------------------------------------------- | -------------------------------------------------------------------- | ------------------------------------------------------ |
|
|
196
|
+
| `env_var` | Inject credential as an environment variable in the subprocess | Process-scoped; destroyed on exit | `GH_TOKEN=<secret>` |
|
|
197
|
+
| `temp_file` | Write credential to a CES-managed temp file; set env var to the path | File deleted after command exits; mode clamped to `0600` | `GOOGLE_APPLICATION_CREDENTIALS=/tmp/ces-xxx/svc.json` |
|
|
198
|
+
| `credential_process` | Spawn a helper inside CES that prints the credential to stdout; inject output as env var | Helper process terminated; output never exposed to the child command | AWS `credential_process` JSON output |
|
|
199
|
+
|
|
200
|
+
The adapter type is declared in the secure command manifest (`authAdapter` field). Validation rejects unknown adapter types and enforces constraints (e.g., `temp_file` mode must be <= `0600`, `credential_process` must specify a `helperCommand`).
|
|
201
|
+
|
|
202
|
+
**Invariant**: Generic authenticated HTTP clients (`curl`, `wget`, `httpie`) and interpreter trampolines (`bash`, `python`, `node`, etc.) are structurally denied as secure command entrypoints. The denied-binary list is checked both at manifest registration time and again at execution time (defense-in-depth).
|
|
203
|
+
|
|
204
|
+
## Egress Proxy Enforcement
|
|
205
|
+
|
|
206
|
+
Secure commands declare one of two egress modes:
|
|
207
|
+
|
|
208
|
+
| Mode | Behavior |
|
|
209
|
+
| ---------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
210
|
+
| `proxy_required` | All network traffic must route through a CES-owned egress proxy session. `HTTP_PROXY`/`HTTPS_PROXY` env vars are injected. Each command profile must declare `allowedNetworkTargets` specifying host patterns, ports, and protocols. |
|
|
211
|
+
| `no_network` | The command has no network requirements. No proxy session is started. Network targets in profiles are rejected as contradictory. This is strictly more restrictive than `proxy_required` — the command receives dead-proxy env vars that block outbound connections. |
|
|
212
|
+
|
|
213
|
+
There is intentionally no `direct` or `unrestricted` egress mode. Commands that contact the network must go through the proxy so CES can enforce target allowlists and produce audit entries. Both modes are valid for command profiles; `no_network` is preferred when a command has no legitimate network needs.
|
|
214
|
+
|
|
215
|
+
**Important**: The `proxy_required` enforcement is **cooperative** — it relies on `HTTP_PROXY`/`HTTPS_PROXY` environment variable injection, not kernel-level network filtering. Binaries that ignore proxy environment variables, implement their own HTTP stacks, or open raw sockets can bypass the proxy allowlist entirely. See [Residual Risk #7](#7-cooperative-isolation-for-both-network-egress-and-filesystem-access) for the full risk analysis and mitigation strategy.
|
|
216
|
+
|
|
217
|
+
## Response Filtering (Defense-in-Depth)
|
|
218
|
+
|
|
219
|
+
HTTP responses returned to the assistant through `make_authenticated_request` pass through a sanitization pipeline:
|
|
220
|
+
|
|
221
|
+
1. **Header filtering** — Only whitelisted response headers (content metadata, rate-limit headers, pagination) are passed through. Auth-bearing headers (`set-cookie`, `www-authenticate`) are stripped.
|
|
222
|
+
2. **Body clamping** — Response bodies are truncated to 256 KB. The full body is never stored.
|
|
223
|
+
3. **Secret scrubbing** — Known credential values are replaced with `[CES:REDACTED]` in the response body. This catches APIs that echo back tokens.
|
|
224
|
+
|
|
225
|
+
**This is explicitly defense-in-depth, not the primary security control.** The primary protections are: (a) the process-boundary isolation that prevents the assistant from ever seeing credential values, (b) the grant system that restricts which credentials can be used, and (c) domain validation that restricts which targets can be contacted. Response filtering is a supplementary layer for APIs that leak secrets in response bodies.
|
|
226
|
+
|
|
227
|
+
## Boundary Invariants
|
|
228
|
+
|
|
229
|
+
These invariants are enforced by guard tests and code review:
|
|
230
|
+
|
|
231
|
+
1. **No cross-package source imports**: `assistant/` must not import from `credential-executor/` and vice versa. Communication is RPC only. Shared types flow through `packages/` only.
|
|
232
|
+
2. **No credential values in assistant process memory**: The assistant sends credential handles (not values) to CES. CES materializes and uses them internally.
|
|
233
|
+
3. **CES tools are the only approved exception to the no-new-tools policy** for credential-bearing execution. All other credential use continues through the existing broker for local deployments.
|
|
234
|
+
4. **Grants and audit logs are CES-internal**: The assistant cannot read CES grant tables or audit logs directly. CES exposes grant status and audit summaries via RPC responses.
|
|
235
|
+
5. **No generic authenticated HTTP clients in secure commands**: `curl`, `wget`, `httpie`, interpreters, and shell trampolines are structurally denied as secure command entrypoints. This is checked at manifest validation and re-checked at execution time.
|
|
236
|
+
6. **Managed CES container runs as non-root**: The CES Docker image runs as `uid 1001` (user `ces`). The CES data volume is owned by this user.
|
|
237
|
+
7. **Single-connection bootstrap socket**: In managed mode, CES accepts exactly one connection on the bootstrap socket, then unlinks it. No second process can connect.
|
|
238
|
+
|
|
239
|
+
## Rollout
|
|
240
|
+
|
|
241
|
+
CES is rolled out incrementally via feature flags, all defaulting to `false` (off). The flags are ordered to allow progressive enablement without user-facing disruption.
|
|
242
|
+
|
|
243
|
+
### Feature flag order
|
|
244
|
+
|
|
245
|
+
Enable flags in this order. Each flag is safe to enable independently, but later flags depend on earlier ones being on for meaningful behavior.
|
|
246
|
+
|
|
247
|
+
| Order | Flag | Gate | Safe to enable alone? |
|
|
248
|
+
| ----- | ------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------- |
|
|
249
|
+
| 1 | `feature_flags.ces-tools.enabled` | Register CES tools (`run_authenticated_command`, `make_authenticated_request`, `manage_secure_command_tool`) in the agent loop | Yes — tools register but are not invoked unless the agent discovers credentials that require CES |
|
|
250
|
+
| 2 | `feature_flags.ces-shell-lockdown.enabled` | Enforce shell lockdown for untrusted agents with CES-active credentials; direct shell access to credentialed services is denied | Yes — only activates when CES credentials are present |
|
|
251
|
+
| 3 | `feature_flags.ces-secure-install.enabled` | Route tool/command installation through CES secure bundle pipeline instead of direct shell | Yes — falls back to standard install if CES is unavailable |
|
|
252
|
+
| 4 | `feature_flags.ces-grant-audit.enabled` | Gate CLI execution of grant listing, grant revocation, and audit inspection commands (commands are always registered but check the flag at runtime) | Yes — read-only inspection surfaces |
|
|
253
|
+
| 5 | `feature_flags.ces-managed-sidecar.enabled` | Use managed sidecar transport (Unix socket) instead of local child-process transport | **No** — requires the CES sidecar container to be present in the pod template. Only enable after the sidecar image is deployed. |
|
|
254
|
+
|
|
255
|
+
### Dark-launching the managed sidecar
|
|
256
|
+
|
|
257
|
+
To dark-launch CES in managed deployments without user impact:
|
|
258
|
+
|
|
259
|
+
1. **Deploy the CES container image** via the `credential_executor_image` field in `POST /v1/internal/assistant-image-releases/`. The warm-pool manager picks it up and includes it in pod templates. The CES container starts, binds its bootstrap socket and health port (8090), but does nothing until an assistant connects.
|
|
260
|
+
|
|
261
|
+
2. **Verify sidecar health** using kubelet probes: `/healthz` (liveness) and `/readyz` (readiness, always returns 200; includes `rpcConnected` field for observability). CES reports its protocol version in both probe responses.
|
|
262
|
+
|
|
263
|
+
3. **Enable `ces-tools`** first on a test cohort. The assistant spawns a local CES child process and registers tools. Verify tool registration, grant creation, and audit logging work end-to-end without affecting existing workflows.
|
|
264
|
+
|
|
265
|
+
4. **Enable `ces-managed-sidecar`** on the same cohort. The assistant switches from child-process transport to the bootstrap Unix socket. CES `/readyz` always returns 200; check the `rpcConnected` field in the response body to verify the assistant has connected.
|
|
266
|
+
|
|
267
|
+
5. **Progressive rollout**: Widen the cohort by enabling flags on more assistants. Monitor for grant failures, materializer errors, and egress proxy issues.
|
|
268
|
+
|
|
269
|
+
### Local deployment rollout
|
|
270
|
+
|
|
271
|
+
Local deployments do not require image changes. Enabling `ces-tools` causes the assistant to spawn CES as a child process automatically. The remaining flags can be enabled in any order.
|
|
272
|
+
|
|
273
|
+
### Guarantees by deployment mode
|
|
274
|
+
|
|
275
|
+
| Guarantee | Local | Managed |
|
|
276
|
+
| ------------------------------------------ | ----------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------ |
|
|
277
|
+
| Process-boundary credential isolation | Strong (separate child process) | Strong (separate container) |
|
|
278
|
+
| Credential value never in assistant memory | Strong | Strong |
|
|
279
|
+
| Grant persistence survives restarts | Strong (filesystem-backed under `~/.vellum/protected/`) | Strong (dedicated `/ces-data` volume) |
|
|
280
|
+
| Network egress enforcement via proxy | Moderate (cooperative via HTTP_PROXY/HTTPS_PROXY env vars; host networking is available — see Risk 7) | Moderate (cooperative via env vars; per-container Calico/NetworkPolicy egress restriction is a v2 design goal but not yet enforced — see Risk 7) |
|
|
281
|
+
| Secret scrubbing in HTTP responses | Defense-in-depth only | Defense-in-depth only |
|
|
282
|
+
| `host_bash` restriction | Policy-only (trust rules can deny, but the tool exists) | Policy-only (same; managed deployments should deny `host_bash` for untrusted agents) |
|
|
283
|
+
|
|
284
|
+
## Rollback
|
|
285
|
+
|
|
286
|
+
### Disabling CES entirely
|
|
287
|
+
|
|
288
|
+
Turn off all CES feature flags. The assistant stops registering CES tools and reverts to the pre-CES credential broker for all credential operations. No data migration is needed — CES grant and audit state is CES-private and does not affect the assistant's own tables.
|
|
289
|
+
|
|
290
|
+
Flag disable order:
|
|
291
|
+
|
|
292
|
+
> **Important — managed deployments**: In managed containers, the assistant image does not ship the `credential-executor` binary, so local CES transport is unavailable. Disabling `ces-managed-sidecar` while `ces-tools` is still enabled will break credentialed tool execution because the assistant cannot fall back to local discovery. Always disable `ces-tools` before `ces-managed-sidecar` in managed deployments.
|
|
293
|
+
|
|
294
|
+
**Local deployments** (reverse of enable order):
|
|
295
|
+
|
|
296
|
+
1. `ces-managed-sidecar` — assistant reverts to local child-process transport
|
|
297
|
+
2. `ces-grant-audit` — inspection surfaces disappear
|
|
298
|
+
3. `ces-secure-install` — tool installation reverts to direct shell
|
|
299
|
+
4. `ces-shell-lockdown` — shell lockdown is lifted
|
|
300
|
+
5. `ces-tools` — CES tools are unregistered from the agent loop
|
|
301
|
+
|
|
302
|
+
**Managed deployments** (`ces-tools` must be disabled before the sidecar):
|
|
303
|
+
|
|
304
|
+
1. `ces-grant-audit` — inspection surfaces disappear
|
|
305
|
+
2. `ces-secure-install` — tool installation reverts to direct shell
|
|
306
|
+
3. `ces-shell-lockdown` — shell lockdown is lifted
|
|
307
|
+
4. `ces-tools` — CES tools are unregistered; assistant reverts to the pre-CES credential broker
|
|
308
|
+
5. `ces-managed-sidecar` — sidecar transport is deactivated (safe now that no CES tools are registered)
|
|
309
|
+
|
|
310
|
+
### Removing the managed sidecar
|
|
311
|
+
|
|
312
|
+
If the CES sidecar container causes pod scheduling issues or resource pressure:
|
|
313
|
+
|
|
314
|
+
1. Disable `ces-tools` on all assistants first (prevents the assistant from attempting CES calls).
|
|
315
|
+
2. Disable `ces-managed-sidecar` on all assistants.
|
|
316
|
+
3. Remove the CES container and its volume mounts from the pod template in vembda.
|
|
317
|
+
4. CES grant/audit data on the `/ces-data` volume is orphaned and can be cleaned up at convenience.
|
|
318
|
+
|
|
319
|
+
The assistant reverts to the pre-CES credential broker once `ces-tools` is disabled.
|
|
320
|
+
|
|
321
|
+
### Partial rollback
|
|
322
|
+
|
|
323
|
+
Individual flags can be disabled independently:
|
|
324
|
+
|
|
325
|
+
- Disabling `ces-shell-lockdown` alone re-allows direct shell access to credentialed services while keeping CES tools available.
|
|
326
|
+
- Disabling `ces-grant-audit` alone removes inspection surfaces without affecting CES execution.
|
|
327
|
+
- Disabling `ces-secure-install` alone reverts tool installation to direct shell without affecting CES command execution.
|
|
328
|
+
|
|
329
|
+
## Residual Risks
|
|
330
|
+
|
|
331
|
+
Risks that are acknowledged and accepted for v1, documented here so they are explicit rather than implied.
|
|
332
|
+
|
|
333
|
+
### 1. `host_bash` is a weaker security tier
|
|
334
|
+
|
|
335
|
+
`host_bash` executes commands on the host machine with full access to the host environment. CES does not intercept or sandbox `host_bash` invocations. An untrusted agent with `host_bash` access can read credentials from environment variables, config files, or keychains.
|
|
336
|
+
|
|
337
|
+
**Mitigation**: Trust rules and permission policies should deny `host_bash` for untrusted agents in managed deployments. This is a policy enforcement, not a technical guarantee. The CES process-boundary isolation only protects operations routed through CES tools.
|
|
338
|
+
|
|
339
|
+
### 2. Response/output filtering is defense-in-depth, not primary protection
|
|
340
|
+
|
|
341
|
+
Secret scrubbing in HTTP response bodies and command stdout/stderr uses exact-match replacement of known credential values. This has inherent limitations:
|
|
342
|
+
|
|
343
|
+
- Only scrubs exact matches (no partial, encoded, or transformed variants)
|
|
344
|
+
- Short secrets (< 8 characters) are skipped to avoid false positives
|
|
345
|
+
- Base64-encoded, URL-encoded, or otherwise transformed secrets are not caught
|
|
346
|
+
|
|
347
|
+
**Mitigation**: The primary protection is the process-boundary isolation — the assistant never receives credential values in the first place. Response filtering is a supplementary layer for APIs that echo secrets back. Do not rely on scrubbing as the sole secret-leakage prevention.
|
|
348
|
+
|
|
349
|
+
### 3. Egress proxy enforcement is process-level, not network-level
|
|
350
|
+
|
|
351
|
+
The egress proxy relies on `HTTP_PROXY`/`HTTPS_PROXY` environment variables. A subprocess that ignores proxy env vars (e.g., a binary that uses its own HTTP stack or raw sockets) can bypass the proxy. This applies to both local and managed deployments — see Risk 7 for details on the managed case.
|
|
352
|
+
|
|
353
|
+
**Mitigation**: For local deployments, the process-level enforcement is accepted as a reasonable trade-off — the user running the assistant locally already has full host access. For managed deployments, per-container Calico network policies restricting CES egress to the proxy sidecar only are a design goal (see Risk 7 mitigation). Until those policies are in place, the denied-binary list and manifest validation reduce the surface for non-cooperating binaries.
|
|
354
|
+
|
|
355
|
+
### 4. No runtime sandboxing beyond process isolation
|
|
356
|
+
|
|
357
|
+
CES commands run in a separate process with a clean environment (isolated HOME, stripped env vars, proxy injection) but do not use container-level or VM-level sandboxing in local mode. A malicious command binary could escalate privileges or read host files.
|
|
358
|
+
|
|
359
|
+
**Mitigation**: Secure command bundles must be published and approved in the CES toolstore before execution. The manifest-driven validation (denied binaries, allowed argv patterns, denied subcommands/flags) restricts what can run. In managed deployments, per-container Calico network policies restricting CES egress are a design goal but not yet enforced (see Risk 7 and the guarantees table above). Current managed mitigation relies on the same denied-binary list and manifest validation as local deployments.
|
|
360
|
+
|
|
361
|
+
### 5. Secure command manifest is trusted after registration
|
|
362
|
+
|
|
363
|
+
Once a secure command manifest passes validation and is published to the toolstore, it is trusted for the lifetime of the bundle digest. There is no runtime re-validation of the bundle contents against the manifest (beyond re-checking the denied-binary list).
|
|
364
|
+
|
|
365
|
+
**Mitigation**: The toolstore uses SHA-256 digests for integrity verification. Manifest registration is a privileged operation gated by CES RPC. Future iterations may add periodic bundle re-verification.
|
|
366
|
+
|
|
367
|
+
### 6. v1 does not support credential rotation notification
|
|
368
|
+
|
|
369
|
+
When a credential is rotated (e.g., an API key is regenerated), existing CES grants referencing that credential continue to use the old value until the grant expires or is revoked. CES does not receive push notifications about credential rotation.
|
|
370
|
+
|
|
371
|
+
**Mitigation**: Grants have TTL-based expiry. Operators can force-revoke grants via the grant revocation RPC. Future iterations may integrate with credential-rotation webhooks to auto-revoke affected grants.
|
|
372
|
+
|
|
373
|
+
### 7. Cooperative isolation for both network egress and filesystem access
|
|
374
|
+
|
|
375
|
+
CES enforces isolation controls cooperatively rather than at the OS level:
|
|
376
|
+
|
|
377
|
+
- **Network egress**: CES injects `HTTP_PROXY`/`HTTPS_PROXY` environment variables into the subprocess environment. A binary that ignores proxy environment variables, implements its own HTTP stack, or opens raw sockets can bypass CES egress controls entirely. Risk #3 above documents this limitation for both local and managed deployments. In managed deployments specifically, current network policies allow public egress from all containers in the pod, so a non-cooperating binary in the CES container can reach the internet without going through the egress proxy.
|
|
378
|
+
|
|
379
|
+
- **Filesystem access**: CES commands run with `cwd` set to a CES-private scratch directory, but this is cooperative — commands can use absolute paths to read or write arbitrary locations on the host filesystem. There is no chroot, filesystem namespace, or bind-mount isolation restricting file access. A command that resolves `..` paths or uses absolute paths can escape the scratch directory to access any file readable/writable by the CES process user.
|
|
380
|
+
|
|
381
|
+
Both limitations stem from the same root cause: v1 relies on process-level conventions (env vars for network, cwd for filesystem) rather than OS-level enforcement primitives.
|
|
382
|
+
|
|
383
|
+
**Mitigation**: The denied-binary list and manifest validation restrict which binaries can run as secure commands, reducing the surface for non-cooperating binaries. In practice, the well-known CLI tools approved as secure command entrypoints (e.g., `gh`, `aws`) respect proxy environment variables. Bundles are content-addressed (SHA-256 digest) and immutable after registration, and user approval is required before any secure command executes — together these form a defense-in-depth chain that compensates for the cooperative enforcement model.
|
|
384
|
+
|
|
385
|
+
True kernel-level enforcement requires OS-level sandboxing — Linux network namespaces for mandatory proxy routing (iptables REDIRECT rules), Kubernetes NetworkPolicies or Calico egress policies restricting CES container traffic to the proxy sidecar only, and filesystem namespaces or chroot for path isolation. This is a v2 concern for **managed mode**, where CES runs in its own container with full namespace support. In **local mode**, kernel-level enforcement is impractical because CES runs as a user-space child process of the assistant — the user already has full host access, and iptables/network namespace manipulation requires root privileges that the assistant does not (and should not) have.
|
|
386
|
+
|
|
387
|
+
### 8. `credential_process` adapter shares cooperative egress limitation with main command
|
|
388
|
+
|
|
389
|
+
The `credential_process` auth adapter executes `sh -c <helperCommand>` with the raw credential piped to stdin. The helper now runs **after** the egress proxy session is started and receives the same proxy environment variables (`HTTP_PROXY`/`HTTPS_PROXY`) as the main command. For `no_network` mode, the helper receives dead-proxy env vars that block outbound connections.
|
|
390
|
+
|
|
391
|
+
This means the helper is subject to the same cooperative egress limitation as the main command (see Risk #7): a helper binary that ignores proxy environment variables, implements its own HTTP stack, or opens raw sockets can still bypass egress controls.
|
|
392
|
+
|
|
393
|
+
**Mitigation**: The `credential_process` helper command is specified in the secure command manifest, which is validated and approved at registration time. Only trusted helper commands should be registered. The helper's purpose is to transform credential format (e.g., producing AWS `credential_process` JSON output), not to make network calls. The denied-binary list prevents generic HTTP clients and interpreters from being used as helpers. The same future mitigations discussed in Risk #7 (per-container network policies, network namespace isolation) would also cover the helper process.
|
|
394
|
+
|
|
395
|
+
## Intentional v1 Out-of-Scope
|
|
396
|
+
|
|
397
|
+
The following capabilities are intentionally deferred beyond v1:
|
|
398
|
+
|
|
399
|
+
- **`local_static` handles in managed mode** — Structurally unsupported due to PBKDF2 key derivation depending on per-container UID (see Locked Decision #2 for full rationale and rejected alternatives). Managed mode returns a clear error and requires `platform_oauth` handles exclusively.
|
|
400
|
+
- **Cloud KMS/Vault integration for secret storage** — v1 reads secrets from filesystem (`~/.vellum/protected/` locally, `/ces-data` in managed). Moving to a dedicated secrets manager is a future enhancement.
|
|
401
|
+
- **Multi-CES-instance support** — Each assistant pod runs exactly one CES sidecar. Horizontal scaling of CES within a pod is not supported.
|
|
402
|
+
- **Cross-pod credential sharing** — CES grants are scoped to a single pod. There is no grant federation across pods or assistant instances.
|
|
403
|
+
- **Browser automation through CES** — Browser form-fill with credential injection is deferred beyond initial rollout.
|
|
404
|
+
- **Credential rotation webhooks** — See residual risk 6 above.
|
|
405
|
+
|
|
406
|
+
## See Also
|
|
407
|
+
|
|
408
|
+
- [Security architecture](architecture/security.md) — existing credential broker and permission model
|
|
409
|
+
- [AGENTS.md](../../AGENTS.md) — tooling direction and CES exception
|
|
410
|
+
- [Tools AGENTS.md](../src/tools/AGENTS.md) — no-new-tools policy and CES exception
|
|
411
|
+
- [Network traffic matrix](../../../vellum-assistant-platform/docs/network-traffic-matrix.md) — managed pod network policies
|
package/knip.json
CHANGED
|
@@ -6,5 +6,9 @@
|
|
|
6
6
|
"src/daemon/main.ts"
|
|
7
7
|
],
|
|
8
8
|
"project": ["src/**/*.ts", "src/**/*.tsx", "scripts/**/*.ts"],
|
|
9
|
-
"ignoreDependencies": [
|
|
9
|
+
"ignoreDependencies": [
|
|
10
|
+
"@vellumai/ces-contracts",
|
|
11
|
+
"@vellumai/credential-storage",
|
|
12
|
+
"@vellumai/egress-proxy"
|
|
13
|
+
]
|
|
10
14
|
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
{
|
|
2
|
+
"lockfileVersion": 1,
|
|
3
|
+
"configVersion": 1,
|
|
4
|
+
"workspaces": {
|
|
5
|
+
"": {
|
|
6
|
+
"name": "@vellumai/ces-contracts",
|
|
7
|
+
"dependencies": {
|
|
8
|
+
"zod": "^4.3.6",
|
|
9
|
+
},
|
|
10
|
+
"devDependencies": {
|
|
11
|
+
"@types/bun": "^1.2.4",
|
|
12
|
+
"typescript": "^5.7.3",
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
"packages": {
|
|
17
|
+
"@types/bun": ["@types/bun@1.3.10", "", { "dependencies": { "bun-types": "1.3.10" } }, "sha512-0+rlrUrOrTSskibryHbvQkDOWRJwJZqZlxrUs1u4oOoTln8+WIXBPmAuCF35SWB2z4Zl3E84Nl/D0P7803nigQ=="],
|
|
18
|
+
|
|
19
|
+
"@types/node": ["@types/node@25.5.0", "", { "dependencies": { "undici-types": "~7.18.0" } }, "sha512-jp2P3tQMSxWugkCUKLRPVUpGaL5MVFwF8RDuSRztfwgN1wmqJeMSbKlnEtQqU8UrhTmzEmZdu2I6v2dpp7XIxw=="],
|
|
20
|
+
|
|
21
|
+
"bun-types": ["bun-types@1.3.10", "", { "dependencies": { "@types/node": "*" } }, "sha512-tcpfCCl6XWo6nCVnpcVrxQ+9AYN1iqMIzgrSKYMB/fjLtV2eyAVEg7AxQJuCq/26R6HpKWykQXuSOq/21RYcbg=="],
|
|
22
|
+
|
|
23
|
+
"typescript": ["typescript@5.9.3", "", { "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" } }, "sha512-jl1vZzPDinLr9eUt3J/t7V6FgNEw9QjvBPdysz9KfQDD41fQrC2Y4vKQdiaUpFT4bXlb1RHhLpp8wtm6M5TgSw=="],
|
|
24
|
+
|
|
25
|
+
"undici-types": ["undici-types@7.18.2", "", {}, "sha512-AsuCzffGHJybSaRrmr5eHr81mwJU3kjw6M+uprWvCXiNeN9SOGwQ3Jn8jb8m3Z6izVgknn1R0FTCEAP2QrLY/w=="],
|
|
26
|
+
|
|
27
|
+
"zod": ["zod@4.3.6", "", {}, "sha512-rftlrkhHZOcjDwkGlnUtZZkvaPHCsDATp4pGpuOOMDaTdDDXF91wuVDJoWoPsKX/3YPQ5fHuF3STjcYyKr+Qhg=="],
|
|
28
|
+
}
|
|
29
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@vellumai/ces-contracts",
|
|
3
|
+
"version": "0.0.1",
|
|
4
|
+
"private": true,
|
|
5
|
+
"type": "module",
|
|
6
|
+
"exports": {
|
|
7
|
+
".": "./src/index.ts",
|
|
8
|
+
"./handles": "./src/handles.ts",
|
|
9
|
+
"./grants": "./src/grants.ts",
|
|
10
|
+
"./rpc": "./src/rpc.ts",
|
|
11
|
+
"./rendering": "./src/rendering.ts"
|
|
12
|
+
},
|
|
13
|
+
"scripts": {
|
|
14
|
+
"typecheck": "bunx tsc --noEmit",
|
|
15
|
+
"test": "bun test src/"
|
|
16
|
+
},
|
|
17
|
+
"dependencies": {
|
|
18
|
+
"zod": "^4.3.6"
|
|
19
|
+
},
|
|
20
|
+
"devDependencies": {
|
|
21
|
+
"@types/bun": "^1.2.4",
|
|
22
|
+
"typescript": "^5.7.3"
|
|
23
|
+
}
|
|
24
|
+
}
|