@vellumai/assistant 0.4.55 → 0.4.57
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ARCHITECTURE.md +161 -167
- package/Dockerfile +9 -9
- package/README.md +12 -12
- package/bun.lock +145 -112
- package/docs/architecture/integrations.md +24 -24
- package/docs/architecture/memory.md +53 -54
- package/docs/architecture/security.md +2 -2
- package/docs/credential-execution-service.md +404 -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 +26 -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 +10 -10
- package/src/__tests__/always-loaded-tools-guard.test.ts +1 -1
- package/src/__tests__/anthropic-provider.test.ts +340 -46
- package/src/__tests__/app-builder-tool-scripts.test.ts +15 -2
- package/src/__tests__/approval-cascade.test.ts +123 -97
- package/src/__tests__/approval-primitive.test.ts +2 -2
- package/src/__tests__/approval-routes-http.test.ts +42 -28
- package/src/__tests__/asset-materialize-tool.test.ts +14 -21
- package/src/__tests__/asset-search-tool.test.ts +6 -13
- 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-events-sse-hardening.test.ts +1 -1
- package/src/__tests__/assistant-feature-flag-guardrails.test.ts +6 -1
- package/src/__tests__/assistant-feature-flags-integration.test.ts +169 -40
- package/src/__tests__/attachments-store.test.ts +2 -2
- package/src/__tests__/avatar-e2e.test.ts +19 -7
- 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 -2
- 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 +4 -4
- package/src/__tests__/call-start-guardian-guard.test.ts +0 -1
- package/src/__tests__/callback-handoff-copy.test.ts +1 -1
- package/src/__tests__/cancel-resolves-conversation-key.test.ts +158 -0
- 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 -1
- package/src/__tests__/channel-readiness-service.test.ts +0 -1
- package/src/__tests__/channel-reply-delivery.test.ts +1 -1
- package/src/__tests__/checker.test.ts +32 -33
- package/src/__tests__/chrome-cdp.test.ts +47 -18
- 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 +45 -46
- package/src/__tests__/config-watcher.test.ts +25 -24
- package/src/__tests__/confirmation-request-guardian-bridge.test.ts +17 -15
- 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} +26 -13
- package/src/__tests__/{session-agent-loop-overflow.test.ts → conversation-agent-loop-overflow.test.ts} +236 -61
- package/src/__tests__/{session-agent-loop.test.ts → conversation-agent-loop.test.ts} +88 -65
- 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} +64 -54
- package/src/__tests__/{session-error.test.ts → conversation-error.test.ts} +98 -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 -24
- package/src/__tests__/{session-load-history-repair.test.ts → conversation-load-history-repair.test.ts} +39 -39
- 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 +47 -47
- package/src/__tests__/{session-pre-run-repair.test.ts → conversation-pre-run-repair.test.ts} +26 -13
- package/src/__tests__/{session-provider-retry-repair.test.ts → conversation-provider-retry-repair.test.ts} +61 -48
- package/src/__tests__/{session-queue.test.ts → conversation-queue.test.ts} +260 -230
- package/src/__tests__/conversation-routes-guardian-reply.test.ts +26 -26
- package/src/__tests__/conversation-routes-slash-commands.test.ts +34 -57
- package/src/__tests__/{session-runtime-assembly.test.ts → conversation-runtime-assembly.test.ts} +187 -175
- 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} +51 -49
- 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} +57 -48
- package/src/__tests__/{session-slash-unknown.test.ts → conversation-slash-unknown.test.ts} +33 -77
- package/src/__tests__/conversation-starter-routes.test.ts +291 -0
- 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__/conversation-wipe.test.ts +438 -0
- package/src/__tests__/{session-workspace-cache-state.test.ts → conversation-workspace-cache-state.test.ts} +31 -39
- package/src/__tests__/{session-workspace-injection.test.ts → conversation-workspace-injection.test.ts} +60 -54
- package/src/__tests__/{session-workspace-tool-tracking.test.ts → conversation-workspace-tool-tracking.test.ts} +56 -50
- 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 +20 -1
- package/src/__tests__/credential-security-invariants.test.ts +5 -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 +227 -1
- package/src/__tests__/credential-vault.test.ts +0 -1
- package/src/__tests__/credentials-cli.test.ts +13 -22
- package/src/__tests__/cu-unified-flow.test.ts +8 -6
- package/src/__tests__/daemon-assistant-events.test.ts +15 -12
- package/src/__tests__/date-context.test.ts +59 -377
- package/src/__tests__/delete-managed-skill-tool.test.ts +0 -1
- package/src/__tests__/diagnostics-export.test.ts +30 -0
- package/src/__tests__/drop-capability-card-state-migration.test.ts +169 -0
- package/src/__tests__/dynamic-page-surface.test.ts +2 -2
- package/src/__tests__/dynamic-skill-workflow-prompt.test.ts +23 -43
- package/src/__tests__/emit-signal-routing-intent.test.ts +4 -4
- package/src/__tests__/encrypted-store.test.ts +237 -15
- package/src/__tests__/ephemeral-permissions.test.ts +4 -5
- package/src/__tests__/event-bus.test.ts +5 -9
- 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__/gateway-only-enforcement.test.ts +2 -2
- package/src/__tests__/gateway-only-guard.test.ts +1 -0
- package/src/__tests__/gemini-image-service.test.ts +4 -4
- package/src/__tests__/gemini-provider.test.ts +6 -9
- 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-binding-drift-heal.test.ts +128 -0
- package/src/__tests__/guardian-decision-primitive-canonical.test.ts +15 -15
- package/src/__tests__/guardian-dispatch.test.ts +9 -10
- 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 +70 -11
- package/src/__tests__/http-user-message-parity.test.ts +32 -19
- package/src/__tests__/intent-routing.test.ts +68 -129
- package/src/__tests__/invite-redemption-service.test.ts +35 -0
- package/src/__tests__/invite-routes-http.test.ts +5 -0
- package/src/__tests__/keychain-broker-client.test.ts +150 -0
- package/src/__tests__/list-messages-attachments.test.ts +1 -1
- 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-proxy-context.test.ts +2 -5
- package/src/__tests__/managed-skill-lifecycle.test.ts +20 -8
- package/src/__tests__/managed-store.test.ts +0 -38
- package/src/__tests__/media-generate-image.test.ts +48 -14
- package/src/__tests__/media-reuse-story.e2e.test.ts +83 -71
- package/src/__tests__/media-visibility-policy.test.ts +10 -10
- package/src/__tests__/memory-context-benchmark.benchmark.test.ts +1 -1
- package/src/__tests__/memory-lifecycle-e2e.test.ts +24 -18
- package/src/__tests__/memory-query-builder.test.ts +2 -2
- package/src/__tests__/memory-recall-quality.test.ts +4 -3
- package/src/__tests__/memory-regressions.test.ts +153 -120
- package/src/__tests__/messaging-send-tool.test.ts +0 -2
- package/src/__tests__/migration-cross-version-compatibility.test.ts +32 -32
- package/src/__tests__/migration-export-http.test.ts +26 -27
- package/src/__tests__/migration-import-commit-http.test.ts +165 -37
- package/src/__tests__/migration-import-preflight-http.test.ts +81 -20
- package/src/__tests__/migration-validate-http.test.ts +16 -16
- package/src/__tests__/model-intents.test.ts +1 -1
- package/src/__tests__/no-domain-routing-in-prompt-guard.test.ts +51 -0
- package/src/__tests__/notification-broadcaster.test.ts +43 -41
- 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 +8 -8
- package/src/__tests__/notification-decision-identity.test.ts +208 -0
- package/src/__tests__/notification-decision-strategy.test.ts +41 -39
- package/src/__tests__/notification-deep-link.test.ts +19 -19
- package/src/__tests__/notification-guardian-path.test.ts +13 -11
- package/src/__tests__/notification-schedule-dedup.test.ts +7 -7
- package/src/__tests__/notification-telegram-adapter.test.ts +5 -5
- package/src/__tests__/oauth-store.test.ts +2 -8
- package/src/__tests__/oauth2-gateway-transport.test.ts +6 -1
- package/src/__tests__/onboarding-template-contract.test.ts +23 -59
- 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-error-scenarios.test.ts +154 -0
- package/src/__tests__/provider-fail-open-selection.test.ts +22 -28
- package/src/__tests__/provider-managed-proxy-integration.test.ts +41 -63
- package/src/__tests__/provider-registry-ollama.test.ts +16 -2
- package/src/__tests__/proxy-approval-callback.test.ts +2 -2
- package/src/__tests__/qdrant-manager.test.ts +7 -7
- package/src/__tests__/ratelimit.test.ts +0 -74
- package/src/__tests__/recording-handler.test.ts +20 -21
- 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-attachment-metadata.test.ts +1 -1
- package/src/__tests__/runtime-events-sse-parity.test.ts +22 -22
- package/src/__tests__/runtime-events-sse.test.ts +16 -8
- package/src/__tests__/scaffold-managed-skill-tool.test.ts +1 -4
- package/src/__tests__/schedule-tools.test.ts +0 -1
- package/src/__tests__/scheduler-recurrence.test.ts +46 -2
- package/src/__tests__/schema-transforms.test.ts +114 -54
- 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 +20 -4
- package/src/__tests__/secret-response-routing.test.ts +1 -1
- package/src/__tests__/secret-routes-managed-proxy.test.ts +82 -2
- package/src/__tests__/secret-scanner-executor.test.ts +1 -4
- package/src/__tests__/send-endpoint-busy.test.ts +134 -62
- package/src/__tests__/send-notification-tool.test.ts +2 -4
- package/src/__tests__/sequence-store.test.ts +5 -5
- package/src/__tests__/shell-credential-ref.test.ts +1 -3
- package/src/__tests__/shell-tool-proxy-mode.test.ts +3 -5
- 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-memory.test.ts +547 -0
- 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 +4 -6
- 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-app-setup-skill-regression.test.ts +37 -0
- package/src/__tests__/slack-channel-config.test.ts +109 -94
- 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 +50 -79
- package/src/__tests__/task-compiler.test.ts +1 -1
- package/src/__tests__/task-management-tools.test.ts +1 -2
- package/src/__tests__/telegram-config.test.ts +121 -0
- package/src/__tests__/terminal-sandbox.test.ts +6 -0
- package/src/__tests__/terminal-tools.test.ts +2 -2
- 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 +68 -16
- package/src/__tests__/tool-execution-pipeline.benchmark.test.ts +0 -1
- package/src/__tests__/tool-executor-lifecycle-events.test.ts +4 -7
- package/src/__tests__/tool-executor-shell-integration.test.ts +1 -2
- package/src/__tests__/tool-executor.test.ts +21 -21
- 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 +9 -2
- package/src/__tests__/trust-context-guards.test.ts +1 -1
- package/src/__tests__/trust-store.test.ts +7 -8
- 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__/twilio-routes.test.ts +1 -18
- package/src/__tests__/ui-file-upload-surface.test.ts +2 -2
- package/src/__tests__/user-reference.test.ts +82 -2
- package/src/__tests__/vbundle-pax-and-symlink.test.ts +196 -0
- package/src/__tests__/verification-control-plane-policy.test.ts +1 -2
- 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 +4 -4
- 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/resvg-lazy.ts +21 -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 +8 -8
- package/src/calls/guardian-question-copy.ts +7 -7
- package/src/calls/relay-access-wait.ts +2 -2
- package/src/calls/relay-server.ts +4 -4
- package/src/calls/twilio-rest.ts +0 -248
- package/src/calls/twilio-routes.ts +1 -1
- package/src/calls/voice-session-bridge.ts +59 -56
- package/src/cli/AGENTS.md +6 -9
- package/src/cli/__tests__/notifications.test.ts +5 -5
- package/src/cli/commands/avatar.ts +343 -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/conversations.ts +386 -0
- package/src/cli/commands/credential-execution.ts +345 -0
- package/src/cli/commands/credentials.ts +108 -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 +4 -4
- 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.ts +169 -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 +63 -47
- package/src/config/bundled-skills/app-builder/TOOLS.json +10 -10
- package/src/config/bundled-skills/browser/SKILL.md +17 -16
- package/src/config/bundled-skills/browser/TOOLS.json +16 -16
- package/src/config/bundled-skills/browser/tools/browser-wait-for-download.ts +1 -1
- package/src/config/bundled-skills/chatgpt-import/SKILL.md +2 -3
- package/src/config/bundled-skills/chatgpt-import/TOOLS.json +1 -1
- package/src/config/bundled-skills/chatgpt-import/tools/chatgpt-import.ts +1 -1
- package/src/config/bundled-skills/claude-code/SKILL.md +6 -7
- package/src/config/bundled-skills/claude-code/TOOLS.json +1 -1
- package/src/config/bundled-skills/computer-use/SKILL.md +3 -5
- package/src/config/bundled-skills/computer-use/TOOLS.json +15 -15
- package/src/config/bundled-skills/contacts/SKILL.md +3 -4
- package/src/config/bundled-skills/contacts/TOOLS.json +8 -4
- package/src/config/bundled-skills/contacts/tools/google-contacts.ts +5 -1
- package/src/config/bundled-skills/document/SKILL.md +4 -4
- package/src/config/bundled-skills/document/TOOLS.json +2 -2
- package/src/config/bundled-skills/followups/SKILL.md +1 -1
- package/src/config/bundled-skills/followups/TOOLS.json +10 -10
- package/src/config/bundled-skills/gmail/SKILL.md +32 -33
- package/src/config/bundled-skills/gmail/TOOLS.json +16 -16
- package/src/config/bundled-skills/gmail/tools/gmail-archive.ts +1 -1
- package/src/config/bundled-skills/gmail/tools/gmail-sender-digest.ts +1 -1
- package/src/config/bundled-skills/google-calendar/SKILL.md +1 -2
- package/src/config/bundled-skills/google-calendar/TOOLS.json +5 -5
- 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/google-calendar/types.ts +1 -1
- package/src/config/bundled-skills/heartbeat/SKILL.md +43 -0
- package/src/config/bundled-skills/image-studio/SKILL.md +3 -4
- package/src/config/bundled-skills/image-studio/TOOLS.json +2 -3
- package/src/config/bundled-skills/image-studio/tools/media-generate-image.ts +44 -23
- package/src/config/bundled-skills/media-processing/SKILL.md +40 -40
- package/src/config/bundled-skills/media-processing/TOOLS.json +8 -8
- package/src/config/bundled-skills/media-processing/__tests__/concurrency-pool.test.ts +2 -2
- package/src/config/bundled-skills/media-processing/__tests__/preprocess.test.ts +1 -1
- package/src/config/bundled-skills/media-processing/services/gemini-map.ts +5 -5
- package/src/config/bundled-skills/media-processing/services/gemini-video.ts +2 -2
- package/src/config/bundled-skills/media-processing/services/preprocess.ts +7 -3
- package/src/config/bundled-skills/media-processing/services/processing-pipeline.ts +2 -2
- package/src/config/bundled-skills/media-processing/services/reduce.ts +3 -3
- package/src/config/bundled-skills/media-processing/tools/analyze-keyframes.ts +3 -3
- package/src/config/bundled-skills/media-processing/tools/generate-clip.ts +2 -2
- package/src/config/bundled-skills/media-processing/tools/query-media-events.ts +1 -1
- package/src/config/bundled-skills/messaging/SKILL.md +39 -37
- package/src/config/bundled-skills/messaging/TOOLS.json +11 -15
- package/src/config/bundled-skills/messaging/tools/messaging-send.ts +1 -1
- package/src/config/bundled-skills/messaging/tools/shared.ts +1 -1
- package/src/config/bundled-skills/notifications/SKILL.md +5 -6
- package/src/config/bundled-skills/notifications/TOOLS.json +3 -3
- package/src/config/bundled-skills/notifications/tools/send-notification.ts +3 -3
- package/src/config/bundled-skills/orchestration/SKILL.md +5 -2
- package/src/config/bundled-skills/orchestration/TOOLS.json +1 -1
- package/src/config/bundled-skills/phone-calls/SKILL.md +37 -21
- package/src/config/bundled-skills/phone-calls/TOOLS.json +3 -3
- package/src/config/bundled-skills/phone-calls/references/CONFIG.md +2 -2
- package/src/config/bundled-skills/phone-calls/references/TRANSCRIPTS.md +2 -2
- package/src/config/bundled-skills/phone-calls/references/TROUBLESHOOTING.md +1 -1
- package/src/config/bundled-skills/playbooks/TOOLS.json +4 -4
- package/src/config/bundled-skills/schedule/SKILL.md +26 -26
- package/src/config/bundled-skills/schedule/TOOLS.json +5 -5
- package/src/config/bundled-skills/screen-watch/SKILL.md +3 -4
- package/src/config/bundled-skills/screen-watch/TOOLS.json +1 -1
- package/src/config/bundled-skills/sequences/SKILL.md +2 -3
- package/src/config/bundled-skills/sequences/TOOLS.json +14 -14
- package/src/config/bundled-skills/sequences/tools/sequence-analytics.ts +2 -2
- package/src/config/bundled-skills/sequences/tools/sequence-create.ts +2 -1
- package/src/config/bundled-skills/sequences/tools/sequence-enroll.ts +2 -2
- package/src/config/bundled-skills/sequences/tools/sequence-enrollment-list.ts +1 -1
- package/src/config/bundled-skills/sequences/tools/sequence-get.ts +1 -1
- package/src/config/bundled-skills/sequences/tools/sequence-import.ts +3 -3
- package/src/config/bundled-skills/sequences/tools/sequence-list.ts +1 -1
- package/src/config/bundled-skills/sequences/tools/sequence-update.ts +3 -2
- package/src/config/bundled-skills/settings/SKILL.md +2 -3
- package/src/config/bundled-skills/settings/TOOLS.json +3 -25
- package/src/config/bundled-skills/settings/tools/open-system-settings.ts +1 -1
- package/src/config/bundled-skills/skill-management/SKILL.md +0 -1
- package/src/config/bundled-skills/skill-management/TOOLS.json +5 -13
- package/src/config/bundled-skills/skills-catalog/SKILL.md +84 -0
- package/src/config/bundled-skills/slack/SKILL.md +2 -3
- package/src/config/bundled-skills/slack/TOOLS.json +8 -8
- package/src/config/bundled-skills/slack/tools/slack-scan-digest.ts +3 -3
- package/src/config/bundled-skills/subagent/SKILL.md +2 -2
- package/src/config/bundled-skills/subagent/TOOLS.json +7 -7
- package/src/config/bundled-skills/tasks/SKILL.md +1 -1
- package/src/config/bundled-skills/tasks/TOOLS.json +9 -9
- package/src/config/bundled-skills/transcribe/SKILL.md +5 -5
- package/src/config/bundled-skills/transcribe/TOOLS.json +1 -1
- package/src/config/bundled-skills/transcribe/tools/transcribe-media.ts +43 -13
- package/src/config/bundled-skills/watcher/SKILL.md +4 -4
- package/src/config/bundled-skills/watcher/TOOLS.json +5 -5
- package/src/config/bundled-tool-registry.ts +9 -2
- package/src/config/env.ts +44 -2
- package/src/config/feature-flag-registry.json +185 -33
- 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 +64 -0
- package/src/config/schemas/skills.ts +131 -81
- package/src/config/schemas/swarm.ts +78 -46
- package/src/config/schemas/timeouts.ts +54 -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 +82 -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} +23 -23
- package/src/daemon/{session-agent-loop.ts → conversation-agent-loop.ts} +99 -101
- package/src/daemon/{session-attachments.ts → conversation-attachments.ts} +35 -9
- package/src/daemon/{session-error.ts → conversation-error.ts} +58 -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} +9 -8
- 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} +156 -285
- package/src/daemon/{session-skill-tools.ts → conversation-skill-tools.ts} +18 -18
- package/src/daemon/{session-slash.ts → conversation-slash.ts} +42 -88
- package/src/daemon/{session-surfaces.ts → conversation-surfaces.ts} +48 -34
- package/src/daemon/{session-tool-setup.ts → conversation-tool-setup.ts} +50 -44
- 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} +98 -73
- package/src/daemon/daemon-control.ts +1 -1
- package/src/daemon/date-context.ts +10 -83
- package/src/daemon/doordash-steps.ts +9 -8
- package/src/daemon/guardian-action-generators.ts +8 -2
- package/src/daemon/handlers/config-channels.ts +19 -6
- package/src/daemon/handlers/config-model.ts +33 -32
- package/src/daemon/handlers/config-slack-channel.ts +35 -7
- package/src/daemon/handlers/config-telegram.ts +6 -1
- 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} +165 -185
- package/src/daemon/handlers/recording.ts +20 -20
- package/src/daemon/handlers/shared.ts +17 -17
- package/src/daemon/handlers/skills.ts +168 -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 +131 -82
- 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 +452 -214
- package/src/daemon/shutdown-handlers.ts +9 -3
- package/src/daemon/startup-error.ts +126 -0
- package/src/daemon/tool-side-effects.ts +42 -18
- package/src/daemon/trace-emitter.ts +28 -5
- 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 +3 -9
- package/src/events/tool-domain-event-publisher.ts +0 -8
- package/src/events/tool-metrics-listener.ts +0 -7
- package/src/events/tool-permission-telemetry-listener.ts +46 -0
- 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 +6 -2
- package/src/instrument.ts +37 -19
- package/src/media/app-icon-generator.ts +17 -10
- package/src/media/avatar-router.ts +17 -10
- package/src/media/gemini-image-service.ts +125 -21
- 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 +343 -23
- package/src/memory/conversation-key-store.ts +40 -4
- package/src/memory/conversation-queries.ts +8 -6
- package/src/memory/conversation-starters-cadence.ts +74 -0
- package/src/memory/conversation-title-service.ts +2 -3
- package/src/memory/db-init.ts +70 -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/cleanup.ts +1 -1
- package/src/memory/job-handlers/conversation-starters.ts +433 -0
- package/src/memory/jobs-store.ts +5 -7
- package/src/memory/jobs-worker.ts +10 -0
- package/src/memory/lifecycle-events-store.ts +63 -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/172-rename-created-by-session-id.ts +27 -0
- package/src/memory/migrations/173-rename-source-session-id.ts +16 -0
- package/src/memory/migrations/174-rename-thread-starters-table.ts +52 -0
- package/src/memory/migrations/175-create-lifecycle-events.ts +15 -0
- package/src/memory/migrations/176-drop-capability-card-state.ts +36 -0
- package/src/memory/migrations/177-create-trace-events-table.ts +40 -0
- package/src/memory/migrations/index.ts +17 -0
- package/src/memory/migrations/registry.ts +32 -0
- package/src/memory/retriever.test.ts +223 -96
- package/src/memory/retriever.ts +115 -138
- 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/infrastructure.ts +29 -0
- package/src/memory/schema/memory-core.ts +27 -0
- package/src/memory/schema/notifications.ts +5 -5
- package/src/memory/schema/tasks.ts +1 -1
- package/src/memory/scoped-approval-grants.ts +14 -14
- package/src/memory/search/formatting.ts +23 -6
- package/src/memory/search/lexical.ts +2 -0
- package/src/memory/search/semantic.ts +2 -0
- package/src/memory/search/staleness.ts +1 -0
- package/src/memory/search/types.ts +7 -3
- package/src/memory/task-memory-cleanup.ts +96 -6
- package/src/memory/trace-event-store.ts +148 -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 +107 -84
- package/src/notifications/deliveries-store.ts +14 -14
- package/src/notifications/emit-signal.ts +16 -16
- package/src/notifications/events-store.ts +4 -4
- package/src/notifications/signal.ts +3 -3
- package/src/notifications/types.ts +16 -12
- package/src/oauth/byo-connection.test.ts +1 -1
- package/src/oauth/manual-token-connection.ts +49 -25
- 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 +21 -7
- package/src/permissions/defaults.ts +4 -4
- 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 +10 -40
- package/src/prompts/cache-boundary.ts +8 -0
- package/src/prompts/system-prompt.ts +155 -743
- package/src/prompts/templates/BOOTSTRAP.md +166 -33
- package/src/prompts/templates/IDENTITY.md +8 -23
- package/src/prompts/templates/SOUL.md +20 -41
- package/src/prompts/templates/UPDATES.md +0 -12
- package/src/prompts/templates/USER.md +3 -19
- package/src/prompts/update-bulletin-format.ts +16 -0
- package/src/prompts/update-bulletin.ts +18 -6
- package/src/prompts/user-reference.ts +14 -16
- package/src/providers/anthropic/client.ts +181 -13
- package/src/providers/gemini/client.ts +6 -9
- package/src/providers/managed-proxy/constants.ts +1 -7
- package/src/providers/managed-proxy/context.ts +26 -1
- package/src/providers/model-intents.ts +5 -5
- package/src/providers/openai/client.ts +10 -1
- package/src/providers/openrouter/client.ts +1 -0
- package/src/providers/provider-availability.ts +39 -0
- package/src/providers/provider-send-message.ts +20 -6
- package/src/providers/ratelimit.ts +0 -35
- package/src/providers/registry.ts +119 -82
- package/src/providers/retry.ts +18 -1
- package/src/runtime/AGENTS.md +5 -5
- package/src/runtime/access-request-helper.ts +3 -3
- 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 +24 -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 +4 -4
- 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/guardian-vellum-migration.ts +63 -1
- package/src/runtime/http-server.ts +76 -35
- 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/migrations/vbundle-builder.ts +212 -32
- package/src/runtime/migrations/vbundle-import-analyzer.ts +74 -8
- package/src/runtime/migrations/vbundle-importer.ts +66 -1
- package/src/runtime/migrations/vbundle-validator.ts +17 -3
- 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 +5 -5
- 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 +36 -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 +22 -5
- package/src/runtime/routes/conversation-management-routes.ts +298 -0
- package/src/runtime/routes/{session-query-routes.ts → conversation-query-routes.ts} +23 -20
- package/src/runtime/routes/conversation-routes.ts +196 -169
- package/src/runtime/routes/conversation-starter-routes.ts +207 -0
- 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/guardian-bootstrap-routes.ts +13 -9
- 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 +2 -2
- package/src/runtime/routes/inbound-stages/secret-ingress-check.ts +1 -1
- package/src/runtime/routes/inbound-stages/verification-intercept.ts +1 -1
- package/src/runtime/routes/log-export-routes.ts +360 -40
- package/src/runtime/routes/migration-routes.ts +25 -13
- 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 +196 -18
- package/src/runtime/routes/settings-routes.ts +31 -18
- 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/telemetry-routes.ts +53 -0
- package/src/runtime/routes/trace-event-routes.ts +62 -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 +4 -4
- package/src/runtime/trust-context-resolver.ts +1 -1
- package/src/runtime/verification-outbound-actions.ts +47 -31
- package/src/schedule/scheduler.ts +14 -12
- package/src/security/credential-backend.ts +29 -5
- package/src/security/encrypted-store.ts +292 -48
- 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 +11 -1
- package/src/skills/managed-store.ts +2 -13
- package/src/skills/skill-memory.ts +220 -0
- package/src/subagent/manager.ts +83 -75
- 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 +35 -0
- package/src/telemetry/usage-telemetry-reporter.test.ts +145 -24
- package/src/telemetry/usage-telemetry-reporter.ts +126 -42
- package/src/tools/AGENTS.md +32 -6
- 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/apps/executors.ts +8 -8
- package/src/tools/apps/registry.ts +1 -1
- package/src/tools/assets/materialize.ts +39 -24
- package/src/tools/assets/search.ts +21 -21
- package/src/tools/browser/__tests__/auth-cache.test.ts +2 -2
- package/src/tools/browser/__tests__/auth-detector.test.ts +4 -4
- package/src/tools/browser/auth-detector.ts +6 -6
- package/src/tools/browser/browser-execution.ts +76 -46
- package/src/tools/browser/browser-handoff.ts +12 -9
- package/src/tools/browser/browser-manager.ts +91 -81
- package/src/tools/browser/browser-screencast.ts +30 -28
- package/src/tools/browser/chrome-cdp.ts +5 -5
- package/src/tools/browser/jit-auth.ts +2 -2
- package/src/tools/browser/network-recorder.test.ts +2 -2
- package/src/tools/browser/network-recorder.ts +3 -3
- package/src/tools/browser/runtime-check.ts +3 -3
- 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 +11 -11
- package/src/tools/computer-use/definitions.ts +18 -18
- 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-types.ts +5 -5
- package/src/tools/credentials/broker.ts +16 -16
- package/src/tools/credentials/metadata-store.ts +46 -227
- package/src/tools/credentials/resolve.ts +3 -2
- package/src/tools/credentials/selection.ts +1 -1
- package/src/tools/credentials/tool-policy.ts +1 -1
- package/src/tools/credentials/vault.ts +115 -25
- package/src/tools/document/document-tool.ts +3 -3
- package/src/tools/execution-target.ts +2 -2
- package/src/tools/executor.ts +147 -12
- package/src/tools/filesystem/edit.ts +2 -2
- package/src/tools/filesystem/read.ts +1 -1
- package/src/tools/filesystem/write.ts +1 -1
- 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 +3 -2
- package/src/tools/host-filesystem/read.ts +3 -2
- package/src/tools/host-filesystem/write.ts +2 -2
- package/src/tools/host-terminal/host-shell.ts +60 -12
- package/src/tools/mcp/mcp-tool-factory.ts +7 -6
- package/src/tools/memory/definitions.ts +6 -5
- package/src/tools/memory/handlers.test.ts +1 -1
- package/src/tools/memory/handlers.ts +1 -1
- package/src/tools/network/__tests__/web-search.test.ts +3 -3
- package/src/tools/network/domain-normalize.ts +2 -2
- package/src/tools/network/script-proxy/session-manager.ts +292 -517
- package/src/tools/network/web-fetch.ts +2 -2
- package/src/tools/network/web-search.ts +7 -7
- package/src/tools/permission-checker.ts +43 -28
- package/src/tools/registry.ts +20 -8
- package/src/tools/schedule/list.ts +2 -2
- package/src/tools/schema-transforms.ts +31 -21
- package/src/tools/secret-detection-handler.ts +4 -9
- package/src/tools/sensitive-output-placeholders.ts +1 -1
- package/src/tools/shared/filesystem/edit-engine.ts +1 -1
- package/src/tools/shared/filesystem/file-ops-service.ts +3 -3
- package/src/tools/shared/filesystem/image-read.ts +25 -5
- package/src/tools/shared/filesystem/path-policy.ts +2 -2
- package/src/tools/shared/shell-output.ts +1 -1
- package/src/tools/side-effects.ts +3 -2
- package/src/tools/skills/execute.ts +1 -1
- package/src/tools/skills/load.ts +18 -4
- package/src/tools/skills/sandbox-runner.ts +3 -4
- 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 +3 -3
- package/src/tools/subagent/spawn.ts +3 -3
- package/src/tools/subagent/status.ts +10 -4
- package/src/tools/swarm/delegate.ts +13 -13
- package/src/tools/system/avatar-generator.ts +52 -79
- package/src/tools/system/request-permission.ts +5 -4
- package/src/tools/terminal/backends/native.ts +51 -11
- package/src/tools/terminal/backends/types.ts +7 -0
- package/src/tools/terminal/parser.ts +6 -6
- package/src/tools/terminal/safe-env.ts +4 -1
- package/src/tools/terminal/sandbox-diagnostics.ts +1 -1
- package/src/tools/terminal/shell.ts +114 -10
- package/src/tools/tool-approval-handler.ts +23 -29
- package/src/tools/tool-manifest.ts +45 -2
- package/src/tools/types.ts +30 -7
- package/src/tools/ui-surface/definitions.ts +9 -37
- package/src/tools/watch/screen-watch.ts +6 -6
- package/src/tools/watch/watch-state.ts +33 -26
- package/src/tools/watcher/list.ts +1 -1
- package/src/util/clipboard.ts +1 -1
- package/src/util/device-id.ts +101 -0
- package/src/util/logger.ts +7 -2
- package/src/util/platform.ts +10 -0
- package/src/util/retry.ts +29 -1
- 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/007-web-search-provider-rename.ts +37 -0
- package/src/workspace/migrations/registry.ts +22 -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__/cli-help-reference-sync.test.ts +0 -26
- package/src/__tests__/handlers-task-submit-slash.test.ts +0 -39
- package/src/__tests__/onboarding-starter-tasks.test.ts +0 -190
- 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/commands/sessions.ts +0 -253
- package/src/cli/http-client.ts +0 -76
- package/src/cli/reference.ts +0 -36
- package/src/daemon/install-cli-launchers.ts +0 -170
- package/src/daemon/session-evictor.ts +0 -203
- package/src/runtime/routes/session-management-routes.ts +0 -190
- 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
|
@@ -430,7 +430,7 @@ sequenceDiagram
|
|
|
430
430
|
| `ask_missing_credential` | A known template pattern matches but no credential is bound to the session |
|
|
431
431
|
| `ask_unauthenticated` | Completely unknown host — prompt for unauthenticated access |
|
|
432
432
|
|
|
433
|
-
**Trust rule persistence**: The `createProxyApprovalCallback` in `
|
|
433
|
+
**Trust rule persistence**: The `createProxyApprovalCallback` in `conversation-tool-setup.ts` is wired into the session startup path and routes policy "ask" decisions through the existing `PermissionPrompter` UI. Trust rules use the `network_request` tool name (not `proxy:*`) with URL-based scope patterns (e.g., `https://api.example.com/*`), aligning with the `buildCommandCandidates()` allowlist generation in `checker.ts`.
|
|
434
434
|
|
|
435
435
|
**Proxied bash permission restriction**: The `ToolExecutor` sets `persistentDecisionsAllowed = false` when the bash tool is invoked with `network_mode: 'proxied'`. This prevents users from saving permanent trust rules for proxied bash commands, since the proxy session's credential scope can change between invocations.
|
|
436
436
|
|
|
@@ -499,7 +499,7 @@ The proxy subsystem intercepts outbound HTTPS requests and injects stored creden
|
|
|
499
499
|
| `assistant/src/tools/network/script-proxy/logging.ts` | Log sanitization (header/URL redaction) and safe decision trace builders for policy and credential resolution |
|
|
500
500
|
| `assistant/src/tools/network/script-proxy/types.ts` | Type definitions — session, policy decisions, approval callback |
|
|
501
501
|
| `assistant/src/tools/executor.ts` | `persistentDecisionsAllowed` gate — disables trust rule saving for proxied bash |
|
|
502
|
-
| `assistant/src/daemon/
|
|
502
|
+
| `assistant/src/daemon/conversation-tool-setup.ts` | `createProxyApprovalCallback` — wired into session startup, uses `network_request` tool name with URL-based trust rules |
|
|
503
503
|
| `assistant/src/permissions/checker.ts` | `network_request` trust rule matching and risk classification (Medium) |
|
|
504
504
|
|
|
505
505
|
### Runtime Wiring Summary
|
|
@@ -508,13 +508,13 @@ The proxy subsystem is fully wired, including credential injection. The session
|
|
|
508
508
|
|
|
509
509
|
- **MITM handler config**: `mitmHandler` is configured with the local CA path and a `rewriteCallback` that performs per-credential specificity-based template selection — for each credential it picks the most specific matching header template (exact > wildcard), blocks on same-credential equal-specificity ties or cross-credential ambiguity, and for the winning `header`-type template resolves the secret from secure storage and sets the outbound header. Wildcard patterns (`*.fal.run`) match the bare apex domain (`fal.run`) via apex-inclusive matching.
|
|
510
510
|
- **Policy callback**: `evaluateRequestWithApproval()` is called via the `policyCallback`; for `'matched'` decisions it injects credential headers (reading the secret value at injection time), while `'ambiguous'` decisions are blocked and `'ask_*'` decisions route through the approval callback
|
|
511
|
-
- **Approval callback**: `createProxyApprovalCallback()` from `
|
|
511
|
+
- **Approval callback**: `createProxyApprovalCallback()` from `conversation-tool-setup.ts` routes approval prompts through the `PermissionPrompter`, using the `network_request` tool name with URL-based trust rules
|
|
512
512
|
- **networkMode plumbing**: `shell.ts` passes `{ networkMode }` to `wrapCommand()`, which forwards it to the native backend
|
|
513
513
|
- **Session lifecycle**: `createSession` / `startSession` / `stopSession` with idle timeout and per-conversation limits
|
|
514
514
|
|
|
515
515
|
---
|
|
516
516
|
|
|
517
|
-
## Asset Search and Materialize — Cross-
|
|
517
|
+
## Asset Search and Materialize — Cross-Conversation Media Reuse
|
|
518
518
|
|
|
519
519
|
The `asset_search` and `asset_materialize` tools enable the assistant to discover and use previously uploaded media assets (images, documents, audio) across conversations. Assets are stored as base64-encoded blobs in the `attachments` table and linked to messages via the `message_attachments` join table.
|
|
520
520
|
|
|
@@ -533,7 +533,7 @@ sequenceDiagram
|
|
|
533
533
|
Search->>DB: query attachments (filters)
|
|
534
534
|
DB-->>Search: matching rows (metadata only, no base64)
|
|
535
535
|
Search->>Visibility: filterVisibleAttachments(results, currentContext)
|
|
536
|
-
Note over Visibility: Private-
|
|
536
|
+
Note over Visibility: Private-conversation attachments filtered out<br/>unless viewer is in the same conversation
|
|
537
537
|
Visibility-->>Search: visible results
|
|
538
538
|
Search-->>Model: metadata list (IDs, filenames, types, sizes)
|
|
539
539
|
|
|
@@ -542,24 +542,24 @@ sequenceDiagram
|
|
|
542
542
|
Materialize->>DB: load attachment (including base64 data)
|
|
543
543
|
Materialize->>Visibility: isAttachmentVisible(attachmentCtx, currentCtx)
|
|
544
544
|
Note over Visibility: Second visibility check at materialize time<br/>prevents TOCTOU between search and materialize
|
|
545
|
-
Materialize->>Materialize: size check (max
|
|
545
|
+
Materialize->>Materialize: size check (max 100 MB)
|
|
546
546
|
Materialize->>Sandbox: write decoded bytes to destination
|
|
547
547
|
Materialize-->>Model: "Materialized 'photo.jpg' to /workspace/media/photo.jpg"
|
|
548
548
|
```
|
|
549
549
|
|
|
550
|
-
### Private
|
|
550
|
+
### Private Conversation Visibility Gate
|
|
551
551
|
|
|
552
|
-
Attachments from private
|
|
552
|
+
Attachments from private conversations are only visible to the same private conversation. Standard-conversation attachments are visible everywhere. The policy is enforced at both the search and materialize stages to prevent cross-conversation data leakage.
|
|
553
553
|
|
|
554
554
|
```mermaid
|
|
555
555
|
graph TB
|
|
556
556
|
subgraph "Visibility Rules"
|
|
557
|
-
ATT_STD["Attachment from<br/>standard
|
|
558
|
-
ATT_PVT["Attachment from<br/>private
|
|
557
|
+
ATT_STD["Attachment from<br/>standard conversation"]
|
|
558
|
+
ATT_PVT["Attachment from<br/>private conversation"]
|
|
559
559
|
|
|
560
|
-
VIEWER_ANY["Any
|
|
561
|
-
VIEWER_SAME["Same private
|
|
562
|
-
VIEWER_OTHER["Different private
|
|
560
|
+
VIEWER_ANY["Any conversation<br/>(standard or private)"]
|
|
561
|
+
VIEWER_SAME["Same private conversation<br/>(matching conversationId)"]
|
|
562
|
+
VIEWER_OTHER["Different private conversation<br/>or standard conversation"]
|
|
563
563
|
end
|
|
564
564
|
|
|
565
565
|
ATT_STD -->|"always visible"| VIEWER_ANY
|
|
@@ -567,11 +567,11 @@ graph TB
|
|
|
567
567
|
ATT_PVT -->|"hidden"| VIEWER_OTHER
|
|
568
568
|
```
|
|
569
569
|
|
|
570
|
-
**Source conversation lookup**: The `getAttachmentSourceConversations()` function traces an attachment's lineage through `message_attachments` -> `messages` -> `conversations` to determine which
|
|
570
|
+
**Source conversation lookup**: The `getAttachmentSourceConversations()` function traces an attachment's lineage through `message_attachments` -> `messages` -> `conversations` to determine which conversations it belongs to and whether any of them are private.
|
|
571
571
|
|
|
572
|
-
**Mixed-source attachments**: If an attachment is linked to messages in both standard and private conversations (e.g., the user shared the same file in two
|
|
572
|
+
**Mixed-source attachments**: If an attachment is linked to messages in both standard and private conversations (e.g., the user shared the same file in two conversations), the attachment is treated as globally visible because at least one source is non-private.
|
|
573
573
|
|
|
574
|
-
**Orphan attachments**: Attachments with no message linkage (orphans) are treated as universally visible rather than hidden, since they have no private-
|
|
574
|
+
**Orphan attachments**: Attachments with no message linkage (orphans) are treated as universally visible rather than hidden, since they have no private-conversation provenance.
|
|
575
575
|
|
|
576
576
|
### Search Capabilities
|
|
577
577
|
|
|
@@ -586,18 +586,18 @@ graph TB
|
|
|
586
586
|
### Materialize Safeguards
|
|
587
587
|
|
|
588
588
|
- **Sandbox path enforcement**: Destination path must resolve inside the sandbox working directory
|
|
589
|
-
- **Size limit**:
|
|
589
|
+
- **Size limit**: 100 MB ceiling prevents materializing excessively large attachments
|
|
590
590
|
- **Double visibility check**: Both `asset_search` and `asset_materialize` independently verify visibility, preventing TOCTOU races between search and use
|
|
591
591
|
- **Risk level**: Both tools are `RiskLevel.Low` since they read existing data and write only within the sandbox
|
|
592
592
|
|
|
593
593
|
### Key Source Files
|
|
594
594
|
|
|
595
|
-
| File | Role
|
|
596
|
-
| ------------------------------------------------- |
|
|
597
|
-
| `assistant/src/tools/assets/search.ts` | `asset_search` tool — cross-
|
|
598
|
-
| `assistant/src/tools/assets/materialize.ts` | `asset_materialize` tool — decode and write attachment to sandbox path
|
|
599
|
-
| `assistant/src/daemon/media-visibility-policy.ts` | Pure policy module — `isAttachmentVisible()`, `filterVisibleAttachments()`
|
|
600
|
-
| `assistant/src/memory/schema.ts` | `attachments` and `message_attachments` table schemas
|
|
601
|
-
| `assistant/src/memory/conversation-crud.ts` | `
|
|
595
|
+
| File | Role |
|
|
596
|
+
| ------------------------------------------------- | --------------------------------------------------------------------------------------------- |
|
|
597
|
+
| `assistant/src/tools/assets/search.ts` | `asset_search` tool — cross-conversation attachment metadata search with visibility filtering |
|
|
598
|
+
| `assistant/src/tools/assets/materialize.ts` | `asset_materialize` tool — decode and write attachment to sandbox path |
|
|
599
|
+
| `assistant/src/daemon/media-visibility-policy.ts` | Pure policy module — `isAttachmentVisible()`, `filterVisibleAttachments()` |
|
|
600
|
+
| `assistant/src/memory/schema.ts` | `attachments` and `message_attachments` table schemas |
|
|
601
|
+
| `assistant/src/memory/conversation-crud.ts` | `getConversationType()` — conversation type lookup for visibility context |
|
|
602
602
|
|
|
603
603
|
---
|
|
@@ -51,7 +51,7 @@ graph TB
|
|
|
51
51
|
HYBRID["Hybrid Search<br/>dense + sparse RRF on Qdrant"]
|
|
52
52
|
RECENCY["Recency Search<br/>conversation-scoped, DB only"]
|
|
53
53
|
MERGE["Merge + Deduplicate<br/>weighted score combination"]
|
|
54
|
-
SCOPE["Scope Filter<br/>scope_id filtering<br/>(strict | global_fallback)<br/>Private
|
|
54
|
+
SCOPE["Scope Filter<br/>scope_id filtering<br/>(strict | global_fallback)<br/>Private conversations: own scope + 'default'"]
|
|
55
55
|
TIER["Tier Classification<br/>score > 0.8 → tier 1<br/>score > 0.6 → tier 2<br/>below → dropped"]
|
|
56
56
|
STALE["Staleness Computation<br/>kind-specific lifetimes<br/>+ reinforcement from<br/>source conversation count"]
|
|
57
57
|
DEMOTE["Stale Demotion<br/>very_stale tier 1 → tier 2"]
|
|
@@ -75,7 +75,7 @@ graph TB
|
|
|
75
75
|
OVF_T4["Tier 4: Injection downgrade<br/>→ minimal mode"]
|
|
76
76
|
OVF_POLICY["Overflow policy resolver<br/>auto_compress / request_approval / fail_gracefully"]
|
|
77
77
|
OVF_APPROVE["Approval gate<br/>PermissionPrompter"]
|
|
78
|
-
OVF_DENY["Graceful deny message<br/>(not
|
|
78
|
+
OVF_DENY["Graceful deny message<br/>(not conversation_error)"]
|
|
79
79
|
end
|
|
80
80
|
|
|
81
81
|
MSG_IN --> STORE
|
|
@@ -149,7 +149,7 @@ Normal context compaction (the "Context Window Management" subgraph above) runs
|
|
|
149
149
|
|
|
150
150
|
When compaction alone is insufficient — either because the conversation grew too fast between turns or because a single turn contains extremely large payloads — the overflow recovery pipeline takes over. The pipeline's first tier (forced compaction) reuses the same `maybeCompact()` summarization machinery but with emergency parameters: `force: true` bypasses cooldown guards, `minKeepRecentUserTurns: 0` allows summarizing even the most recent history, and `targetInputTokensOverride` sets a tighter budget. Subsequent tiers (tool-result truncation, media stubbing, injection downgrade) apply progressively more aggressive payload reduction without involving the summarizer.
|
|
151
151
|
|
|
152
|
-
If all four reducer tiers are exhausted, the overflow policy resolver determines whether to compress the latest user turn. In interactive sessions, the user is prompted for approval before this lossy step. If the user declines, the session emits a graceful assistant explanation message rather than a `
|
|
152
|
+
If all four reducer tiers are exhausted, the overflow policy resolver determines whether to compress the latest user turn. In interactive sessions, the user is prompted for approval before this lossy step. If the user declines, the session emits a graceful assistant explanation message rather than a `conversation_error`, ending the turn cleanly. Non-interactive sessions auto-compress without prompting.
|
|
153
153
|
|
|
154
154
|
The key distinction: normal compaction is a cost-optimized background process that preserves conversational quality; overflow recovery is a convergence mechanism that prioritizes session survival over context richness. Both share the same summarization infrastructure but operate under different pressure thresholds and constraints.
|
|
155
155
|
|
|
@@ -250,7 +250,7 @@ The recall pipeline runs on every turn that passes the `needsMemory` gate (skips
|
|
|
250
250
|
9. **Two-layer XML injection** (`formatting.ts`): Budget-aware rendering into four XML sections:
|
|
251
251
|
|
|
252
252
|
```xml
|
|
253
|
-
<memory_context>
|
|
253
|
+
<memory_context __injected>
|
|
254
254
|
|
|
255
255
|
<user_identity>
|
|
256
256
|
<!-- identity-kind tier 1 items (plain statements) -->
|
|
@@ -273,7 +273,7 @@ The recall pipeline runs on every turn that passes the `needsMemory` gate (skips
|
|
|
273
273
|
|
|
274
274
|
Empty sections are omitted. Each section has a per-item token budget (150 tokens for tier 1, 100 for tier 2). Tier 1 sections consume budget first; tier 2 uses the remainder.
|
|
275
275
|
|
|
276
|
-
10. **Injection strategy**: The rendered `<memory_context>` block is
|
|
276
|
+
10. **Injection strategy**: The rendered `<memory_context __injected>` block is prepended as a text content block to the last user message (`injectMemoryRecallAsUserBlock`), following the same pattern as workspace, temporal, and other runtime injections. Stripping is handled by the generic `stripUserTextBlocksByPrefix` mechanism matching the `<memory_context __injected>` prefix (with a backward-compat entry for the legacy `<memory_context>` prefix from older history). This avoids synthetic message pairs and preserves prompt prefix caching between turns.
|
|
277
277
|
|
|
278
278
|
### Internal-Only Trust Gating
|
|
279
279
|
|
|
@@ -283,7 +283,7 @@ Two trust gates enforce trust-class-based access control over the memory pipelin
|
|
|
283
283
|
|
|
284
284
|
- **Write gate** (`indexer.ts`): The `extract_items` job only runs for messages from trusted actors (guardian or undefined provenance). Messages from untrusted actors (`trusted_contact`, `unknown`) are still segmented and embedded — so they appear in conversation context — but no item extraction is triggered. This prevents untrusted channels from injecting or mutating long-term memory items.
|
|
285
285
|
|
|
286
|
-
- **Read gate** (`
|
|
286
|
+
- **Read gate** (`conversation-memory.ts`): When the current session's actor is untrusted, the memory recall pipeline returns a no-op context — no recall injection. This ensures untrusted actors cannot surface or exploit previously extracted memory.
|
|
287
287
|
|
|
288
288
|
Trust policy is **cross-channel and trust-class-based**: decisions use `trustContext.trustClass`, not the channel string. Desktop sessions default to `trustClass: 'guardian'`. External channels (Telegram, WhatsApp, phone) provide explicit trust context via the resolver. Messages without provenance metadata are treated as trusted (guardian); all new messages carry provenance.
|
|
289
289
|
|
|
@@ -310,36 +310,36 @@ When the embedding backend or Qdrant is unavailable:
|
|
|
310
310
|
|
|
311
311
|
---
|
|
312
312
|
|
|
313
|
-
## Private
|
|
313
|
+
## Private Conversations — Isolated Memory and Strict Side-Effect Controls
|
|
314
314
|
|
|
315
|
-
Private
|
|
315
|
+
Private conversations provide per-conversation memory isolation and stricter tool execution controls. When a conversation is created with `conversationType: 'private'`, the daemon assigns it a unique memory scope and enforces additional safeguards to prevent unintended side effects.
|
|
316
316
|
|
|
317
317
|
### Schema Columns
|
|
318
318
|
|
|
319
319
|
Two columns on the `conversations` table drive the feature:
|
|
320
320
|
|
|
321
|
-
| Column
|
|
322
|
-
|
|
|
323
|
-
| `
|
|
324
|
-
| `memory_scope_id`
|
|
321
|
+
| Column | Type | Values | Purpose |
|
|
322
|
+
| ------------------- | ---------------------------------- | ------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------ |
|
|
323
|
+
| `conversation_type` | `text NOT NULL DEFAULT 'standard'` | `'standard'` or `'private'` | Determines whether the conversation uses shared or isolated memory and permission policies |
|
|
324
|
+
| `memory_scope_id` | `text NOT NULL DEFAULT 'default'` | `'default'` for standard conversations; `'private:<uuid>'` for private conversations | Scopes all memory writes (items, segments) to this namespace; embeddings are isolated indirectly via their parent item/segment |
|
|
325
325
|
|
|
326
326
|
### Memory Isolation
|
|
327
327
|
|
|
328
328
|
```mermaid
|
|
329
329
|
graph TB
|
|
330
|
-
subgraph "Standard
|
|
330
|
+
subgraph "Standard Conversation"
|
|
331
331
|
STD_WRITE["Memory writes<br/>→ scope_id = 'default'"]
|
|
332
332
|
STD_READ["Memory recall<br/>reads scope_id = 'default' only"]
|
|
333
333
|
end
|
|
334
334
|
|
|
335
|
-
subgraph "Private
|
|
335
|
+
subgraph "Private Conversation"
|
|
336
336
|
PVT_WRITE["Memory writes<br/>→ scope_id = 'private:<uuid>'"]
|
|
337
337
|
PVT_READ["Memory recall<br/>reads scope_id = 'private:<uuid>'<br/>+ fallback to 'default'"]
|
|
338
338
|
end
|
|
339
339
|
|
|
340
340
|
subgraph "Shared Memory Pool"
|
|
341
|
-
DEFAULT_SCOPE["'default' scope<br/>(all standard
|
|
342
|
-
PRIVATE_SCOPE["'private:<uuid>' scope<br/>(isolated to one
|
|
341
|
+
DEFAULT_SCOPE["'default' scope<br/>(all standard conversation memories)"]
|
|
342
|
+
PRIVATE_SCOPE["'private:<uuid>' scope<br/>(isolated to one conversation)"]
|
|
343
343
|
end
|
|
344
344
|
|
|
345
345
|
STD_WRITE --> DEFAULT_SCOPE
|
|
@@ -349,53 +349,53 @@ graph TB
|
|
|
349
349
|
PVT_READ -.->|"fallback"| DEFAULT_SCOPE
|
|
350
350
|
```
|
|
351
351
|
|
|
352
|
-
**Write isolation**: All memory items and segments created during a private
|
|
352
|
+
**Write isolation**: All memory items and segments created during a private conversation are tagged with its `memory_scope_id` (e.g. `'private:abc123'`). Embeddings are isolated indirectly — they reference scoped items/segments via `target_type`/`target_id`, so scope filtering at the item/segment level cascades to their embeddings. All scoped data is invisible to standard conversations and other private conversations.
|
|
353
353
|
|
|
354
|
-
**Read fallback**: When recalling memories for a private
|
|
354
|
+
**Read fallback**: When recalling memories for a private conversation, the retriever queries both the conversation's own scope and the `'default'` scope. This ensures the assistant still has access to general knowledge (user profile, preferences, facts) learned in standard conversations, while private-conversation-specific memories take precedence in ranking. The fallback is implemented via `ScopePolicyOverride` with `fallbackToDefault: true`, which overrides the global scope policy on a per-call basis.
|
|
355
355
|
|
|
356
356
|
### SessionMemoryPolicy
|
|
357
357
|
|
|
358
|
-
The daemon derives a `SessionMemoryPolicy` from the conversation's `
|
|
358
|
+
The daemon derives a `SessionMemoryPolicy` from the conversation's `conversation_type` and `memory_scope_id` when creating or restoring a session:
|
|
359
359
|
|
|
360
360
|
```typescript
|
|
361
361
|
interface SessionMemoryPolicy {
|
|
362
362
|
scopeId: string; // 'default' or 'private:<uuid>'
|
|
363
|
-
includeDefaultFallback: boolean; // true for private
|
|
364
|
-
strictSideEffects: boolean; // true for private
|
|
363
|
+
includeDefaultFallback: boolean; // true for private conversations
|
|
364
|
+
strictSideEffects: boolean; // true for private conversations
|
|
365
365
|
}
|
|
366
366
|
```
|
|
367
367
|
|
|
368
|
-
Standard
|
|
368
|
+
Standard conversations use `DEFAULT_MEMORY_POLICY` (`{ scopeId: 'default', includeDefaultFallback: false, strictSideEffects: false }`). Private conversations set all three fields: the private scope ID, default-fallback enabled, and strict side-effect controls enabled.
|
|
369
369
|
|
|
370
370
|
### Strict Side-Effect Prompt Gate
|
|
371
371
|
|
|
372
|
-
When `strictSideEffects` is `true` (all private
|
|
372
|
+
When `strictSideEffects` is `true` (all private conversations), the `ToolExecutor` promotes any `allow` permission decision to `prompt` for side-effect tools — even when a trust rule would normally auto-allow the invocation. Deny decisions are preserved unchanged; only `allow` -> `prompt` promotion occurs.
|
|
373
373
|
|
|
374
374
|
```mermaid
|
|
375
375
|
graph TB
|
|
376
|
-
TOOL["Tool invocation in<br/>private
|
|
376
|
+
TOOL["Tool invocation in<br/>private conversation"] --> PERM["Normal permission check<br/>(trust rules + risk level)"]
|
|
377
377
|
PERM --> DECISION{"Decision?"}
|
|
378
378
|
DECISION -->|"deny"| DENY["Blocked<br/>(unchanged)"]
|
|
379
379
|
DECISION -->|"prompt"| PROMPT["Prompt user<br/>(unchanged)"]
|
|
380
380
|
DECISION -->|"allow"| SIDE_CHECK{"isSideEffectTool()?"}
|
|
381
381
|
SIDE_CHECK -->|"no"| ALLOW["Auto-allow<br/>(read-only tools pass)"]
|
|
382
|
-
SIDE_CHECK -->|"yes"| FORCE_PROMPT["Promote to prompt<br/>'Private
|
|
382
|
+
SIDE_CHECK -->|"yes"| FORCE_PROMPT["Promote to prompt<br/>'Private conversation: side-effect<br/>tools require explicit approval'"]
|
|
383
383
|
```
|
|
384
384
|
|
|
385
|
-
This ensures that file writes, bash commands, host operations, and other mutating tools always require explicit user confirmation in private
|
|
385
|
+
This ensures that file writes, bash commands, host operations, and other mutating tools always require explicit user confirmation in private conversations, providing an additional safety layer for sensitive conversations.
|
|
386
386
|
|
|
387
387
|
### Key Source Files
|
|
388
388
|
|
|
389
|
-
| File
|
|
390
|
-
|
|
|
391
|
-
| `assistant/src/memory/schema.ts`
|
|
392
|
-
| `assistant/src/daemon/
|
|
393
|
-
| `assistant/src/daemon/server.ts`
|
|
394
|
-
| `assistant/src/daemon/
|
|
395
|
-
| `assistant/src/tools/executor.ts`
|
|
396
|
-
| `assistant/src/memory/search/types.ts`
|
|
397
|
-
| `assistant/src/memory/retriever.ts`
|
|
398
|
-
| `assistant/src/daemon/
|
|
389
|
+
| File | Role |
|
|
390
|
+
| ------------------------------------------------- | ------------------------------------------------------------------------------------------ |
|
|
391
|
+
| `assistant/src/memory/schema.ts` | `conversations` table: `conversationType` and `memoryScopeId` column definitions |
|
|
392
|
+
| `assistant/src/daemon/conversation.ts` | `SessionMemoryPolicy` interface and `DEFAULT_MEMORY_POLICY` constant |
|
|
393
|
+
| `assistant/src/daemon/server.ts` | `deriveMemoryPolicy()` — maps conversation type to memory policy |
|
|
394
|
+
| `assistant/src/daemon/conversation-tool-setup.ts` | Propagates `memoryPolicy.strictSideEffects` as `forcePromptSideEffects` into `ToolContext` |
|
|
395
|
+
| `assistant/src/tools/executor.ts` | `forcePromptSideEffects` gate — promotes allow to prompt for side-effect tools |
|
|
396
|
+
| `assistant/src/memory/search/types.ts` | `ScopePolicyOverride` interface for per-call scope control |
|
|
397
|
+
| `assistant/src/memory/retriever.ts` | `buildScopeFilter()` — builds scope ID list from override or global config |
|
|
398
|
+
| `assistant/src/daemon/conversation-memory.ts` | Wires `scopeId` and `includeDefaultFallback` into recall |
|
|
399
399
|
|
|
400
400
|
---
|
|
401
401
|
|
|
@@ -452,19 +452,19 @@ The Anthropic provider places `cache_control: { type: 'ephemeral' }` on the **la
|
|
|
452
452
|
|
|
453
453
|
### Key files
|
|
454
454
|
|
|
455
|
-
| File
|
|
456
|
-
|
|
|
457
|
-
| `assistant/src/workspace/top-level-scanner.ts`
|
|
458
|
-
| `assistant/src/workspace/top-level-renderer.ts`
|
|
459
|
-
| `assistant/src/daemon/
|
|
460
|
-
| `assistant/src/onboarding/onboarding-orchestrator.ts`
|
|
461
|
-
| `assistant/src/daemon/
|
|
455
|
+
| File | Role |
|
|
456
|
+
| ------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
|
|
457
|
+
| `assistant/src/workspace/top-level-scanner.ts` | Synchronous directory scanner with `MAX_TOP_LEVEL_ENTRIES` cap |
|
|
458
|
+
| `assistant/src/workspace/top-level-renderer.ts` | Renders `TopLevelSnapshot` to `<workspace_top_level>` XML block |
|
|
459
|
+
| `assistant/src/daemon/conversation-runtime-assembly.ts` | Runtime injections and strip helpers (`<workspace_top_level>`, `<temporal_context>`, `<channel_onboarding_playbook>`, `<onboarding_mode>`) |
|
|
460
|
+
| `assistant/src/onboarding/onboarding-orchestrator.ts` | Builds assistant-owned onboarding runtime guidance from channel playbook + transport metadata |
|
|
461
|
+
| `assistant/src/daemon/conversation-agent-loop.ts` | Agent loop orchestration, runtime injection wiring, strip chain |
|
|
462
462
|
|
|
463
463
|
---
|
|
464
464
|
|
|
465
465
|
## Temporal Context Injection — Date Grounding
|
|
466
466
|
|
|
467
|
-
The session injects a `<temporal_context>` block into every user message at runtime, giving the model awareness of the current date, current local time, current UTC time, timezone source metadata
|
|
467
|
+
The session injects a `<temporal_context>` block into every user message at runtime, giving the model awareness of the current date, current local time, current UTC time, and timezone source metadata. This enables reliable reasoning about dates and times without persisting volatile temporal data in conversation history.
|
|
468
468
|
|
|
469
469
|
### Per-turn flow
|
|
470
470
|
|
|
@@ -488,18 +488,17 @@ graph TB
|
|
|
488
488
|
- **Clock source invariant**: Absolute time (`now`) always comes from the assistant host clock (`Date.now()`), never from channel/client clocks.
|
|
489
489
|
- **Timezone precedence**: If `ui.userTimezone` is configured, temporal context uses it for local-date interpretation. Otherwise it falls back to memory-stored timezone, then assistant host timezone.
|
|
490
490
|
- **Timezone-aware**: Uses `Intl.DateTimeFormat` APIs for DST-safe date arithmetic and timezone validation/canonicalization.
|
|
491
|
-
- **Bounded output**: Hard-capped at 1500 characters and 14 horizon entries to prevent prompt bloat.
|
|
492
491
|
- **Runtime-only**: The injected `<temporal_context>` block is stripped from `this.messages` after the agent loop completes via `stripTemporalContext`. It never persists in conversation history.
|
|
493
492
|
- **Specific strip prefix**: The strip function matches the exact injected prefix (`<temporal_context>\nToday:`) to avoid accidentally removing user-authored text that starts with `<temporal_context>`.
|
|
494
493
|
- **Retry paths**: Temporal context is included in all three `applyRuntimeInjections` call sites (main path, compact retry, media-trim retry).
|
|
495
494
|
|
|
496
495
|
### Key files
|
|
497
496
|
|
|
498
|
-
| File
|
|
499
|
-
|
|
|
500
|
-
| `assistant/src/daemon/date-context.ts`
|
|
501
|
-
| `assistant/src/daemon/
|
|
502
|
-
| `assistant/src/daemon/
|
|
497
|
+
| File | Role |
|
|
498
|
+
| ------------------------------------------------------- | --------------------------------------------------------------------------------------- |
|
|
499
|
+
| `assistant/src/daemon/date-context.ts` | `buildTemporalContext()` — generates the `<temporal_context>` XML block |
|
|
500
|
+
| `assistant/src/daemon/conversation-runtime-assembly.ts` | `injectTemporalContext()` / `stripTemporalContext()` helpers |
|
|
501
|
+
| `assistant/src/daemon/conversation-agent-loop.ts` | Wiring: computes temporal context, passes to `applyRuntimeInjections`, strips after run |
|
|
503
502
|
|
|
504
503
|
---
|
|
505
504
|
|
|
@@ -550,7 +549,7 @@ graph TB
|
|
|
550
549
|
|
|
551
550
|
1. **Lazy initialization**: The git repository is created on first use, not at workspace creation. When `ensureInitialized()` is called, it checks for a `.git` directory. If absent, it runs `git init`, creates a `.gitignore` (excluding `data/`, `logs/`, `*.log`, `*.sock`, `*.pid`, `session-token`), sets the git identity to "Vellum Assistant", and creates an initial baseline commit capturing any pre-existing files. The baseline commit is intentional — it makes `git log`, `git diff`, and `git revert` work cleanly from the start. Both new and existing workspaces get the same treatment. For existing repos (e.g. created by older versions or external tools), `.gitignore` rules and git identity are set idempotently on each init, ensuring proper configuration regardless of how the repo was originally created.
|
|
552
551
|
|
|
553
|
-
2. **Turn-boundary commits**: After each conversation turn (user message + assistant response cycle), `
|
|
552
|
+
2. **Turn-boundary commits**: After each conversation turn (user message + assistant response cycle), `conversation.ts` commits workspace changes via `commitTurnChanges(workspaceDir, sessionId, turnNumber)`. The commit runs in the `finally` block of `runAgentLoop`, guarded by a `turnStarted` flag that is set once the agent loop begins executing. This guarantees a commit attempt even when post-processing (e.g. `resolveAssistantAttachments`) throws, or when the user cancels mid-turn. The commit is raced against a configurable timeout (`workspaceGit.turnCommitMaxWaitMs`, default 4s) via `Promise.race`. If the commit exceeds the timeout, the turn proceeds immediately while the commit continues in the background. Note: the background commit is NOT awaited before the next turn starts, so brief cross-turn file attribution windows are possible but accepted as a tradeoff for responsiveness. Commit outcomes are logged with structured fields (`sessionId`, `turnNumber`, `filesChanged`, `durationMs`) for observability.
|
|
554
553
|
|
|
555
554
|
3. **Heartbeat safety net**: A `HeartbeatService` runs on a 5-minute interval, checking all tracked workspaces for uncommitted changes. It auto-commits when changes exceed either an age threshold (5 minutes since first detected) or a file count threshold (20+ files). This catches changes from long-running bash scripts, background processes, or crashed sessions that miss turn-boundary commits.
|
|
556
555
|
|
|
@@ -562,7 +561,7 @@ graph TB
|
|
|
562
561
|
|
|
563
562
|
7. **Circuit breaker with exponential backoff**: `WorkspaceGitService` tracks consecutive commit failures and backs off exponentially (2s, 4s, 8s... up to 60s configurable max). When the breaker is open, `commitIfDirty()` short-circuits without attempting git operations. On success, the breaker resets. State transitions are logged at info/warn level with structured fields (`consecutiveFailures`, `backoffMs`).
|
|
564
563
|
|
|
565
|
-
8. **Turn-commit timeout protection**: The turn-boundary commit in `
|
|
564
|
+
8. **Turn-commit timeout protection**: The turn-boundary commit in `conversation.ts` uses `Promise.race` with a configurable timeout (`workspaceGit.turnCommitMaxWaitMs`, default 4s). If the commit exceeds the timeout, the turn proceeds immediately (the commit continues in the background). This prevents slow git operations from blocking the conversation loop.
|
|
566
565
|
|
|
567
566
|
9. **Non-blocking enrichment queue**: After each successful commit, a `CommitEnrichmentService` runs async enrichment fire-and-forget. The queue has configurable max size (default 50), concurrency (default 1), per-job timeout (default 30s), and retry count (default 2 with exponential backoff). On queue overflow, the oldest job is dropped with a warning log. On graceful shutdown, in-flight jobs drain while pending jobs are discarded. Currently writes placeholder JSON metadata to git notes (`refs/notes/vellum`) as a scaffold for future LLM enrichment.
|
|
568
567
|
|
|
@@ -592,7 +591,7 @@ graph TB
|
|
|
592
591
|
- **Commit at turn boundaries, not per-tool-call**: A single commit per turn captures all file mutations from that turn atomically. This avoids noisy per-file commits and keeps the history meaningful.
|
|
593
592
|
- **Lazy init with baseline commit**: The repo is created on first use, not at daemon startup. Existing workspaces get their files captured in an "Initial commit: migrated existing workspace" on first use, rather than requiring an explicit migration step. The baseline commit ensures `git log`, `git diff`, and `git revert` work cleanly from the start.
|
|
594
593
|
- **Mutex serialization**: All git operations go through a per-workspace `Mutex` to prevent concurrent `git add`/`git commit` from corrupting the index. The mutex uses a FIFO wait queue.
|
|
595
|
-
- **Finally-block commit guarantee in
|
|
594
|
+
- **Finally-block commit guarantee in conversation-agent-loop.ts**: Turn commits run in the `finally` block of `runAgentLoop`, ensuring they execute even when post-processing throws or the user cancels. The `turnStarted` flag prevents commits for turns that were blocked before the agent loop started. All errors are caught and logged as warnings. The commit is raced against a timeout (`turnCommitMaxWaitMs`, default 4s); if it exceeds the timeout the turn proceeds and the commit continues in the background without synchronization. Brief cross-turn file attribution is accepted as a tradeoff for keeping the conversation loop responsive.
|
|
596
595
|
- **Branch enforcement at init time**: `ensureOnMainLocked()` is called during initialization to ensure the workspace is on the `main` branch. If the workspace is on the wrong branch or in a detached HEAD state, it auto-corrects to `main` with a warning log. Per-commit enforcement is unnecessary since nothing in the codebase switches branches.
|
|
597
596
|
- **We intentionally don't provide custom history APIs** -- assistants should use git commands naturally via Bash (e.g. `git log`, `git diff`, `git show`). The workspace git repo is a standard git repository that any tool can interact with.
|
|
598
597
|
|
|
@@ -606,7 +605,7 @@ graph TB
|
|
|
606
605
|
| `assistant/src/workspace/turn-commit.ts` | `commitTurnChanges()`: turn-boundary commit with structured metadata + enrichment enqueue |
|
|
607
606
|
| `assistant/src/workspace/provider-commit-message-generator.ts` | `ProviderCommitMessageGenerator`: LLM-based commit message generation with circuit breaker and deterministic fallback |
|
|
608
607
|
| `assistant/src/workspace/heartbeat-service.ts` | `HeartbeatService`: periodic safety-net auto-commits, shutdown commits, enrichment enqueue |
|
|
609
|
-
| `assistant/src/daemon/
|
|
608
|
+
| `assistant/src/daemon/conversation-agent-loop.ts` | Integration: turn-boundary commit with `raceWithTimeout` protection in `runAgentLoop` finally block |
|
|
610
609
|
| `assistant/src/daemon/lifecycle.ts` | Integration: `HeartbeatService` start/stop and shutdown commit |
|
|
611
610
|
| `assistant/src/config/schema.ts` | `WorkspaceGitConfigSchema`: timeout, backoff, and enrichment queue configuration |
|
|
612
611
|
|
|
@@ -197,7 +197,7 @@ The `tool_permission_simulate` HTTP endpoint lets clients dry-run a tool invocat
|
|
|
197
197
|
- The daemon runs `classifyRisk()` and `check()` against the live trust rules, then returns the decision (`allow`, `deny`, or `prompt`), risk level, reason, matched rule ID, and (when decision is `prompt`) the full `promptPayload` with allowlist/scope options.
|
|
198
198
|
- **Simulation-only allow/deny**: A simulated `allow` or `deny` decision does not persist any state. No trust rules are created or modified.
|
|
199
199
|
- **Always-allow persistence**: When the tester UI's "Always Allow" action is used, the client sends a separate `add_trust_rule` message that persists the rule to `trust.json`, identical to the existing confirmation flow.
|
|
200
|
-
- **Private-
|
|
200
|
+
- **Private-conversation override**: When `forcePromptSideEffects` is true, side-effect tools that would normally be auto-allowed are promoted to `prompt`.
|
|
201
201
|
- **Non-interactive override**: When `isInteractive` is false, `prompt` decisions are converted to `deny` (no client available to approve).
|
|
202
202
|
|
|
203
203
|
---
|
|
@@ -299,7 +299,7 @@ The `allowOneTimeSend` config gate (default: `false`) enables a secondary "Send
|
|
|
299
299
|
| File | Role |
|
|
300
300
|
| ---------------------------------------------------- | --------------------------------------------------------------------- |
|
|
301
301
|
| `assistant/src/tools/credentials/vault.ts` | `credential_store` tool — store, list, delete, prompt actions |
|
|
302
|
-
| `assistant/src/security/secure-keys.ts` |
|
|
302
|
+
| `assistant/src/security/secure-keys.ts` | Async secure key CRUD via keychain broker and encrypted file store |
|
|
303
303
|
| `assistant/src/tools/credentials/metadata-store.ts` | JSON file metadata CRUD for credential records |
|
|
304
304
|
| `assistant/src/tools/credentials/broker.ts` | Brokered credential access with policy enforcement and transient send |
|
|
305
305
|
| `assistant/src/tools/credentials/policy-validate.ts` | Policy input validation (allowedTools, allowedDomains) |
|