@vellumai/assistant 0.4.43 → 0.4.45

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (713) hide show
  1. package/.prettierignore +4 -0
  2. package/ARCHITECTURE.md +46 -44
  3. package/README.md +15 -16
  4. package/bun.lock +10 -35
  5. package/docs/architecture/integrations.md +102 -215
  6. package/docs/architecture/keychain-broker.md +1 -1
  7. package/docs/architecture/memory.md +2 -2
  8. package/docs/architecture/scheduling.md +1 -1
  9. package/docs/architecture/security.md +11 -11
  10. package/docs/error-handling.md +1 -1
  11. package/docs/trusted-contact-access.md +3 -3
  12. package/drizzle/meta/0000_snapshot.json +34 -100
  13. package/drizzle/meta/_journal.json +1 -1
  14. package/drizzle.config.ts +4 -4
  15. package/package.json +3 -2
  16. package/scripts/capture-x-graphql.ts +237 -141
  17. package/scripts/generate-bundled-tool-registry.ts +223 -0
  18. package/src/__tests__/access-request-decision.test.ts +0 -1
  19. package/src/__tests__/actor-token-service.test.ts +23 -24
  20. package/src/__tests__/agent-loop.test.ts +0 -131
  21. package/src/__tests__/always-loaded-tools-guard.test.ts +71 -0
  22. package/src/__tests__/amazon-cdp-integration.test.ts +11 -9
  23. package/src/__tests__/approval-primitive.test.ts +0 -1
  24. package/src/__tests__/approval-routes-http.test.ts +11 -3
  25. package/src/__tests__/asset-materialize-tool.test.ts +0 -1
  26. package/src/__tests__/asset-search-tool.test.ts +0 -1
  27. package/src/__tests__/assistant-attachment-directive.test.ts +1 -1
  28. package/src/__tests__/assistant-events-sse-hardening.test.ts +0 -1
  29. package/src/__tests__/assistant-feature-flag-guardrails.test.ts +0 -2
  30. package/src/__tests__/assistant-feature-flags-integration.test.ts +70 -18
  31. package/src/__tests__/assistant-id-boundary-guard.test.ts +6 -6
  32. package/src/__tests__/attachments-store.test.ts +0 -1
  33. package/src/__tests__/avatar-e2e.test.ts +74 -115
  34. package/src/__tests__/avatar-router.test.ts +25 -62
  35. package/src/__tests__/browser-manager.test.ts +24 -0
  36. package/src/__tests__/browser-skill-baseline-tool-payload.test.ts +4 -3
  37. package/src/__tests__/browser-skill-endstate.test.ts +8 -11
  38. package/src/__tests__/btw-routes.test.ts +326 -0
  39. package/src/__tests__/bundled-asset.test.ts +1 -1
  40. package/src/__tests__/bundled-skill-retrieval-guard.test.ts +23 -9
  41. package/src/__tests__/call-controller.test.ts +0 -1
  42. package/src/__tests__/call-conversation-messages.test.ts +0 -1
  43. package/src/__tests__/call-domain.test.ts +0 -1
  44. package/src/__tests__/call-pointer-messages.test.ts +0 -1
  45. package/src/__tests__/call-recovery.test.ts +0 -1
  46. package/src/__tests__/call-routes-http.test.ts +0 -1
  47. package/src/__tests__/call-store.test.ts +0 -1
  48. package/src/__tests__/canonical-guardian-store.test.ts +0 -1
  49. package/src/__tests__/channel-approval-routes.test.ts +1 -1
  50. package/src/__tests__/channel-approvals.test.ts +1 -1
  51. package/src/__tests__/channel-delivery-store.test.ts +0 -1
  52. package/src/__tests__/channel-guardian.test.ts +5 -7
  53. package/src/__tests__/channel-retry-sweep.test.ts +0 -1
  54. package/src/__tests__/checker.test.ts +32 -36
  55. package/src/__tests__/compaction.benchmark.test.ts +16 -14
  56. package/src/__tests__/computer-use-session-lifecycle.test.ts +10 -11
  57. package/src/__tests__/computer-use-session-working-dir.test.ts +2 -6
  58. package/src/__tests__/computer-use-skill-lifecycle-cleanup.test.ts +2 -5
  59. package/src/__tests__/computer-use-tools.test.ts +35 -31
  60. package/src/__tests__/config-schema.test.ts +11 -15
  61. package/src/__tests__/config-watcher.test.ts +0 -1
  62. package/src/__tests__/confirmation-request-guardian-bridge.test.ts +0 -1
  63. package/src/__tests__/conflict-store.test.ts +0 -1
  64. package/src/__tests__/connection-policy.test.ts +4 -7
  65. package/src/__tests__/contacts-tools.test.ts +0 -1
  66. package/src/__tests__/context-memory-e2e.test.ts +2 -4
  67. package/src/__tests__/context-overflow-reducer.test.ts +2 -4
  68. package/src/__tests__/context-window-manager.test.ts +147 -60
  69. package/src/__tests__/contradiction-checker.test.ts +0 -1
  70. package/src/__tests__/conversation-attention-store.test.ts +0 -1
  71. package/src/__tests__/conversation-attention-telegram.test.ts +1 -1
  72. package/src/__tests__/conversation-pairing.test.ts +2 -2
  73. package/src/__tests__/conversation-routes-guardian-reply.test.ts +31 -7
  74. package/src/__tests__/conversation-routes-slash-commands.test.ts +381 -0
  75. package/src/__tests__/conversation-store.test.ts +0 -1
  76. package/src/__tests__/conversation-unread-route.test.ts +1 -2
  77. package/src/__tests__/credential-security-invariants.test.ts +8 -8
  78. package/src/__tests__/cross-provider-web-search.test.ts +353 -0
  79. package/src/__tests__/daemon-assistant-events.test.ts +6 -7
  80. package/src/__tests__/db-schedule-syntax-migration.test.ts +15 -3
  81. package/src/__tests__/delete-managed-skill-tool.test.ts +5 -9
  82. package/src/__tests__/deterministic-verification-control-plane.test.ts +0 -1
  83. package/src/__tests__/diagnostics-export.test.ts +189 -0
  84. package/src/__tests__/dynamic-skill-workflow-prompt.test.ts +0 -1
  85. package/src/__tests__/emit-signal-routing-intent.test.ts +3 -3
  86. package/src/__tests__/entity-extractor.test.ts +0 -1
  87. package/src/__tests__/entity-search.test.ts +0 -1
  88. package/src/__tests__/ephemeral-permissions.test.ts +2 -4
  89. package/src/__tests__/error-handler-friendly-messages.test.ts +46 -0
  90. package/src/__tests__/file-read-tool.test.ts +86 -0
  91. package/src/__tests__/followup-tools.test.ts +0 -1
  92. package/src/__tests__/frontmatter.test.ts +77 -34
  93. package/src/__tests__/gateway-only-enforcement.test.ts +0 -1
  94. package/src/__tests__/gateway-only-guard.test.ts +1 -1
  95. package/src/__tests__/guardian-action-conversation-turn.test.ts +0 -1
  96. package/src/__tests__/guardian-action-followup-executor.test.ts +0 -1
  97. package/src/__tests__/guardian-action-followup-store.test.ts +0 -1
  98. package/src/__tests__/guardian-action-grant-mint-consume.test.ts +0 -1
  99. package/src/__tests__/guardian-action-late-reply.test.ts +0 -1
  100. package/src/__tests__/guardian-action-store.test.ts +0 -1
  101. package/src/__tests__/guardian-action-sweep.test.ts +0 -1
  102. package/src/__tests__/guardian-decision-primitive-canonical.test.ts +0 -1
  103. package/src/__tests__/guardian-dispatch.test.ts +1 -2
  104. package/src/__tests__/guardian-grant-minting.test.ts +1 -1
  105. package/src/__tests__/guardian-outbound-http.test.ts +0 -1
  106. package/src/__tests__/guardian-principal-id-roundtrip.test.ts +0 -1
  107. package/src/__tests__/guardian-routing-invariants.test.ts +1 -1
  108. package/src/__tests__/guardian-routing-state.test.ts +0 -1
  109. package/src/__tests__/guardian-verification-voice-binding.test.ts +0 -1
  110. package/src/__tests__/guardian-verify-setup-skill-regression.test.ts +3 -5
  111. package/src/__tests__/handlers-user-message-approval-consumption.test.ts +28 -426
  112. package/src/__tests__/host-bash-proxy.test.ts +335 -0
  113. package/src/__tests__/host-file-proxy.test.ts +374 -0
  114. package/src/__tests__/host-shell-tool.test.ts +147 -1
  115. package/src/__tests__/http-user-message-parity.test.ts +361 -0
  116. package/src/__tests__/inbound-invite-redemption.test.ts +0 -1
  117. package/src/__tests__/integration-status.test.ts +3 -8
  118. package/src/__tests__/intent-routing.test.ts +7 -46
  119. package/src/__tests__/invite-redemption-service.test.ts +0 -1
  120. package/src/__tests__/invite-routes-http.test.ts +0 -1
  121. package/src/__tests__/llm-usage-store.test.ts +0 -1
  122. package/src/__tests__/managed-avatar-client.test.ts +101 -55
  123. package/src/__tests__/managed-skill-lifecycle.test.ts +9 -18
  124. package/src/__tests__/managed-store.test.ts +94 -21
  125. package/src/__tests__/media-reuse-story.e2e.test.ts +0 -1
  126. package/src/__tests__/memory-context-benchmark.benchmark.test.ts +2 -4
  127. package/src/__tests__/memory-lifecycle-e2e.test.ts +0 -1
  128. package/src/__tests__/memory-recall-quality.test.ts +0 -1
  129. package/src/__tests__/memory-regressions.experimental.test.ts +0 -1
  130. package/src/__tests__/memory-regressions.test.ts +0 -1
  131. package/src/__tests__/memory-retrieval.benchmark.test.ts +0 -1
  132. package/src/__tests__/memory-upsert-concurrency.test.ts +0 -1
  133. package/src/__tests__/messaging-send-tool.test.ts +35 -0
  134. package/src/__tests__/messaging-skill-split.test.ts +138 -0
  135. package/src/__tests__/migration-cross-version-compatibility.test.ts +0 -1
  136. package/src/__tests__/migration-export-http.test.ts +2 -3
  137. package/src/__tests__/migration-import-commit-http.test.ts +1 -2
  138. package/src/__tests__/migration-import-preflight-http.test.ts +1 -2
  139. package/src/__tests__/migration-validate-http.test.ts +1 -2
  140. package/src/__tests__/native-web-search.test.ts +475 -0
  141. package/src/__tests__/navigate-settings-tab.test.ts +84 -0
  142. package/src/__tests__/non-member-access-request.test.ts +0 -1
  143. package/src/__tests__/notification-broadcaster.test.ts +15 -15
  144. package/src/__tests__/notification-decision-strategy.test.ts +6 -6
  145. package/src/__tests__/notification-deep-link.test.ts +7 -7
  146. package/src/__tests__/notification-guardian-path.test.ts +2 -3
  147. package/src/__tests__/notification-telegram-adapter.test.ts +1 -1
  148. package/src/__tests__/notification-thread-candidates.test.ts +4 -4
  149. package/src/__tests__/onboarding-starter-tasks.test.ts +0 -1
  150. package/src/__tests__/onboarding-template-contract.test.ts +0 -10
  151. package/src/__tests__/playbook-execution.test.ts +0 -1
  152. package/src/__tests__/playbook-tools.test.ts +0 -1
  153. package/src/__tests__/profile-compiler.test.ts +0 -1
  154. package/src/__tests__/provider-fail-open-selection.test.ts +12 -2
  155. package/src/__tests__/provider-managed-proxy-integration.test.ts +25 -0
  156. package/src/__tests__/qdrant-collection-migration.test.ts +223 -0
  157. package/src/__tests__/recording-handler.test.ts +30 -94
  158. package/src/__tests__/registry.test.ts +28 -35
  159. package/src/__tests__/relay-server.test.ts +0 -1
  160. package/src/__tests__/ride-shotgun-handler.test.ts +4 -20
  161. package/src/__tests__/runtime-attachment-metadata.test.ts +0 -1
  162. package/src/__tests__/runtime-events-sse-parity.test.ts +3 -4
  163. package/src/__tests__/runtime-events-sse.test.ts +0 -1
  164. package/src/__tests__/sandbox-diagnostics.test.ts +0 -1
  165. package/src/__tests__/scaffold-managed-skill-tool.test.ts +30 -28
  166. package/src/__tests__/schedule-store.test.ts +441 -1
  167. package/src/__tests__/schedule-tools.test.ts +468 -7
  168. package/src/__tests__/scheduler-recurrence.test.ts +196 -23
  169. package/src/__tests__/scoped-approval-grants.test.ts +0 -1
  170. package/src/__tests__/scoped-grant-security-matrix.test.ts +0 -1
  171. package/src/__tests__/secret-prompt-log-hygiene.test.ts +6 -3
  172. package/src/__tests__/secret-response-routing.test.ts +4 -1
  173. package/src/__tests__/send-endpoint-busy.test.ts +14 -5
  174. package/src/__tests__/send-notification-tool.test.ts +0 -7
  175. package/src/__tests__/sequence-store.test.ts +0 -1
  176. package/src/__tests__/server-history-render.test.ts +1 -2
  177. package/src/__tests__/session-abort-tool-results.test.ts +0 -1
  178. package/src/__tests__/session-agent-loop.test.ts +46 -6
  179. package/src/__tests__/session-confirmation-signals.test.ts +7 -46
  180. package/src/__tests__/session-conflict-gate.test.ts +2 -6
  181. package/src/__tests__/session-error.test.ts +5 -14
  182. package/src/__tests__/session-init.benchmark.test.ts +3 -5
  183. package/src/__tests__/session-load-history-repair.test.ts +0 -1
  184. package/src/__tests__/session-media-retry.test.ts +12 -74
  185. package/src/__tests__/session-pre-run-repair.test.ts +0 -1
  186. package/src/__tests__/session-profile-injection.test.ts +2 -6
  187. package/src/__tests__/session-provider-retry-repair.test.ts +2 -6
  188. package/src/__tests__/session-queue.test.ts +94 -139
  189. package/src/__tests__/session-skill-tools.test.ts +115 -115
  190. package/src/__tests__/session-slash-known.test.ts +0 -1
  191. package/src/__tests__/session-slash-queue.test.ts +0 -1
  192. package/src/__tests__/session-slash-unknown.test.ts +0 -1
  193. package/src/__tests__/session-surfaces-task-progress.test.ts +34 -0
  194. package/src/__tests__/session-usage.test.ts +0 -1
  195. package/src/__tests__/session-workspace-cache-state.test.ts +2 -6
  196. package/src/__tests__/session-workspace-injection.test.ts +2 -6
  197. package/src/__tests__/session-workspace-tool-tracking.test.ts +2 -6
  198. package/src/__tests__/skill-feature-flags-integration.test.ts +180 -184
  199. package/src/__tests__/skill-feature-flags.test.ts +125 -18
  200. package/src/__tests__/skill-load-feature-flag.test.ts +1 -2
  201. package/src/__tests__/skill-load-tool.test.ts +194 -2
  202. package/src/__tests__/skill-projection-feature-flag.test.ts +27 -16
  203. package/src/__tests__/skill-projection.benchmark.test.ts +15 -14
  204. package/src/__tests__/skills.test.ts +14 -53
  205. package/src/__tests__/slack-channel-config.test.ts +0 -1
  206. package/src/__tests__/slack-inbound-verification.test.ts +0 -1
  207. package/src/__tests__/slack-skill.test.ts +1 -1
  208. package/src/__tests__/starter-task-flow.test.ts +9 -19
  209. package/src/__tests__/subagent-tools.test.ts +2 -2
  210. package/src/__tests__/system-prompt.test.ts +7 -7
  211. package/src/__tests__/task-compiler.test.ts +0 -1
  212. package/src/__tests__/task-management-tools.test.ts +0 -1
  213. package/src/__tests__/task-memory-cleanup.test.ts +0 -1
  214. package/src/__tests__/task-runner.test.ts +0 -1
  215. package/src/__tests__/task-scheduler.test.ts +0 -1
  216. package/src/__tests__/terminal-tools.test.ts +0 -1
  217. package/src/__tests__/test-support/computer-use-skill-harness.ts +2 -4
  218. package/src/__tests__/thread-seed-composer.test.ts +5 -5
  219. package/src/__tests__/tool-approval-handler.test.ts +0 -1
  220. package/src/__tests__/tool-execution-abort-cleanup.test.ts +0 -1
  221. package/src/__tests__/tool-execution-pipeline.benchmark.test.ts +0 -1
  222. package/src/__tests__/tool-executor.test.ts +8 -86
  223. package/src/__tests__/tool-grant-request-escalation.test.ts +0 -1
  224. package/src/__tests__/tool-notification-listener.test.ts +1 -1
  225. package/src/__tests__/tool-preview-lifecycle.test.ts +416 -0
  226. package/src/__tests__/trust-store.test.ts +84 -8
  227. package/src/__tests__/trusted-contact-approval-notifier.test.ts +0 -1
  228. package/src/__tests__/trusted-contact-inline-approval-integration.test.ts +0 -1
  229. package/src/__tests__/trusted-contact-lifecycle-notifications.test.ts +0 -1
  230. package/src/__tests__/trusted-contact-multichannel.test.ts +0 -1
  231. package/src/__tests__/trusted-contact-verification.test.ts +0 -1
  232. package/src/__tests__/twilio-provider.test.ts +0 -1
  233. package/src/__tests__/twilio-routes.test.ts +0 -1
  234. package/src/__tests__/{request-file-tool.test.ts → ui-file-upload-surface.test.ts} +11 -72
  235. package/src/__tests__/update-bulletin.test.ts +0 -1
  236. package/src/__tests__/usage-cache-backfill-migration.test.ts +0 -1
  237. package/src/__tests__/usage-routes.test.ts +0 -1
  238. package/src/__tests__/verification-control-plane-policy.test.ts +4 -4
  239. package/src/__tests__/voice-invite-redemption.test.ts +0 -1
  240. package/src/__tests__/voice-scoped-grant-consumer.test.ts +0 -1
  241. package/src/__tests__/voice-session-bridge.test.ts +9 -1
  242. package/src/__tests__/web-fetch.test.ts +57 -0
  243. package/src/__tests__/workspace-git-service.test.ts +5 -14
  244. package/src/__tests__/workspace-policy.test.ts +0 -1
  245. package/src/agent/loop.ts +22 -34
  246. package/src/bundler/bundle-signer.ts +4 -4
  247. package/src/calls/call-controller.ts +1 -1
  248. package/src/calls/relay-server.ts +1 -1
  249. package/src/calls/twilio-rest.ts +1 -1
  250. package/src/calls/voice-session-bridge.ts +3 -1
  251. package/src/cli/__tests__/notifications.test.ts +3 -4
  252. package/src/cli/commands/map.ts +2 -6
  253. package/src/cli/commands/mcp.ts +73 -15
  254. package/src/cli/commands/notifications.ts +4 -4
  255. package/src/cli/commands/sessions.ts +9 -1
  256. package/src/cli/commands/skills.ts +6 -10
  257. package/src/cli/http-client.ts +2 -3
  258. package/src/cli/main-screen.tsx +10 -10
  259. package/src/cli/program.ts +0 -4
  260. package/src/cli/reference.ts +0 -2
  261. package/src/cli.ts +15 -9
  262. package/src/config/__tests__/bundled-tool-registry-guard.test.ts +120 -0
  263. package/src/config/bundled-skills/_shared/CLI_RETRIEVAL_PATTERN.md +11 -0
  264. package/src/config/bundled-skills/app-builder/SKILL.md +6 -7
  265. package/src/config/bundled-skills/app-builder/TOOLS.json +0 -4
  266. package/src/config/bundled-skills/browser/SKILL.md +6 -1
  267. package/src/config/bundled-skills/chatgpt-import/SKILL.md +5 -1
  268. package/src/config/bundled-skills/claude-code/SKILL.md +5 -1
  269. package/src/config/bundled-skills/computer-use/SKILL.md +6 -1
  270. package/src/config/bundled-skills/computer-use/TOOLS.json +6 -69
  271. package/src/config/bundled-skills/computer-use/tools/computer-use-click.ts +10 -1
  272. package/src/config/bundled-skills/contacts/SKILL.md +10 -1
  273. package/src/config/bundled-skills/contacts/TOOLS.json +35 -0
  274. package/src/config/bundled-skills/{messaging → contacts}/tools/google-contacts.ts +9 -2
  275. package/src/config/bundled-skills/document/SKILL.md +4 -1
  276. package/src/config/bundled-skills/doordash/SKILL.md +8 -2
  277. package/src/config/bundled-skills/doordash/__tests__/doordash-session.test.ts +1 -82
  278. package/src/config/bundled-skills/doordash/doordash-cli.ts +17 -28
  279. package/src/config/bundled-skills/doordash/lib/session.ts +21 -17
  280. package/src/config/bundled-skills/doordash/lib/shared/platform.ts +4 -1
  281. package/src/config/bundled-skills/followups/SKILL.md +4 -1
  282. package/src/config/bundled-skills/gmail/SKILL.md +180 -0
  283. package/src/config/bundled-skills/gmail/TOOLS.json +506 -0
  284. package/src/config/bundled-skills/gmail/tools/gmail-archive.ts +149 -0
  285. package/src/config/bundled-skills/gmail/tools/gmail-attachments.ts +110 -0
  286. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-draft.ts +1 -1
  287. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-filters.ts +1 -1
  288. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-follow-up.ts +1 -1
  289. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-forward.ts +1 -1
  290. package/src/config/bundled-skills/gmail/tools/gmail-label.ts +50 -0
  291. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-outreach-scan.ts +8 -90
  292. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-send-draft.ts +1 -1
  293. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-sender-digest.ts +2 -2
  294. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-trash.ts +1 -1
  295. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-unsubscribe.ts +1 -1
  296. package/src/config/bundled-skills/{messaging → gmail}/tools/gmail-vacation.ts +1 -1
  297. package/src/config/bundled-skills/gmail/tools/shared.ts +47 -0
  298. package/src/config/bundled-skills/google-calendar/SKILL.md +5 -1
  299. package/src/config/bundled-skills/image-studio/SKILL.md +5 -1
  300. package/src/config/bundled-skills/knowledge-graph/SKILL.md +4 -1
  301. package/src/config/bundled-skills/media-processing/SKILL.md +7 -13
  302. package/src/config/bundled-skills/media-processing/TOOLS.json +0 -22
  303. package/src/config/bundled-skills/media-processing/tools/generate-clip.ts +12 -1
  304. package/src/config/bundled-skills/messaging/SKILL.md +23 -139
  305. package/src/config/bundled-skills/messaging/TOOLS.json +33 -1215
  306. package/src/config/bundled-skills/messaging/tools/gmail-mime-helpers.ts +42 -0
  307. package/src/config/bundled-skills/messaging/tools/messaging-send.ts +165 -2
  308. package/src/config/bundled-skills/messaging/tools/messaging-sender-digest.ts +1 -13
  309. package/src/config/bundled-skills/messaging/tools/shared.ts +81 -34
  310. package/src/config/bundled-skills/notifications/SKILL.md +5 -1
  311. package/src/config/bundled-skills/orchestration/SKILL.md +30 -0
  312. package/src/config/bundled-skills/orchestration/TOOLS.json +35 -0
  313. package/src/config/bundled-skills/{reminder/tools/reminder-cancel.ts → orchestration/tools/swarm-delegate.ts} +3 -3
  314. package/src/config/bundled-skills/phone-calls/SKILL.md +9 -1
  315. package/src/config/bundled-skills/playbooks/SKILL.md +4 -1
  316. package/src/config/bundled-skills/schedule/SKILL.md +70 -9
  317. package/src/config/bundled-skills/schedule/TOOLS.json +38 -6
  318. package/src/config/bundled-skills/screen-watch/SKILL.md +28 -0
  319. package/src/config/bundled-skills/screen-watch/TOOLS.json +35 -0
  320. package/src/config/bundled-skills/{reminder/tools/reminder-create.ts → screen-watch/tools/start-screen-watch.ts} +3 -3
  321. package/src/config/bundled-skills/sequences/SKILL.md +47 -0
  322. package/src/config/bundled-skills/sequences/TOOLS.json +340 -0
  323. package/src/config/bundled-skills/sequences/tools/sequence-update.ts +128 -0
  324. package/src/config/bundled-skills/sequences/tools/shared.ts +9 -0
  325. package/src/config/bundled-skills/settings/SKILL.md +12 -0
  326. package/src/config/bundled-skills/settings/TOOLS.json +112 -0
  327. package/src/config/bundled-skills/settings/tools/navigate-settings-tab.ts +43 -0
  328. package/src/config/bundled-skills/settings/tools/open-system-settings.ts +52 -0
  329. package/src/config/bundled-skills/{computer-use/tools/computer-use-right-click.ts → settings/tools/set-avatar.ts} +2 -6
  330. package/src/{tools/system/voice-config.ts → config/bundled-skills/settings/tools/voice-config-update.ts} +59 -96
  331. package/src/config/bundled-skills/skill-management/SKILL.md +18 -0
  332. package/src/config/bundled-skills/skill-management/TOOLS.json +90 -0
  333. package/src/config/bundled-skills/{computer-use/tools/computer-use-double-click.ts → skill-management/tools/delete-managed.ts} +2 -6
  334. package/src/config/bundled-skills/skill-management/tools/scaffold-managed.ts +12 -0
  335. package/src/config/bundled-skills/slack/SKILL.md +5 -1
  336. package/src/config/bundled-skills/subagent/SKILL.md +4 -1
  337. package/src/config/bundled-skills/tasks/SKILL.md +5 -2
  338. package/src/config/bundled-skills/transcribe/SKILL.md +4 -1
  339. package/src/config/bundled-skills/watcher/SKILL.md +4 -1
  340. package/src/config/bundled-tool-registry.ts +118 -107
  341. package/src/config/env.ts +5 -2
  342. package/src/config/feature-flag-registry.json +33 -9
  343. package/src/config/loader.ts +10 -2
  344. package/src/config/schema.ts +19 -16
  345. package/src/config/schemas/inference.ts +12 -22
  346. package/src/config/schemas/memory-storage.ts +19 -1
  347. package/src/config/schemas/platform.ts +0 -16
  348. package/src/config/skill-state.ts +11 -8
  349. package/src/config/skills.ts +83 -32
  350. package/src/context/token-estimator.ts +11 -0
  351. package/src/context/window-manager.ts +180 -151
  352. package/src/daemon/computer-use-session.ts +11 -43
  353. package/src/daemon/daemon-control.ts +4 -1
  354. package/src/daemon/handlers/config-channels.ts +5 -9
  355. package/src/daemon/handlers/config-ingress.ts +0 -4
  356. package/src/daemon/handlers/config-model.ts +7 -13
  357. package/src/daemon/handlers/config-telegram.ts +4 -8
  358. package/src/daemon/handlers/config-voice.ts +2 -5
  359. package/src/daemon/handlers/dictation.ts +2 -12
  360. package/src/daemon/handlers/identity.ts +0 -105
  361. package/src/daemon/handlers/recording.ts +3 -23
  362. package/src/daemon/handlers/session-history.ts +42 -10
  363. package/src/daemon/handlers/sessions.ts +53 -72
  364. package/src/daemon/handlers/shared.ts +7 -28
  365. package/src/daemon/handlers/skills.ts +31 -27
  366. package/src/daemon/host-bash-proxy.ts +148 -0
  367. package/src/daemon/host-file-proxy.ts +135 -0
  368. package/src/daemon/lifecycle.ts +53 -41
  369. package/src/daemon/mcp-reload-service.ts +123 -0
  370. package/src/daemon/message-protocol.ts +6 -0
  371. package/src/daemon/message-types/apps.ts +0 -25
  372. package/src/daemon/message-types/browser.ts +1 -1
  373. package/src/daemon/message-types/computer-use.ts +1 -4
  374. package/src/daemon/message-types/guardian-actions.ts +1 -1
  375. package/src/daemon/message-types/host-bash.ts +18 -0
  376. package/src/daemon/message-types/host-file.ts +44 -0
  377. package/src/daemon/message-types/integrations.ts +1 -73
  378. package/src/daemon/message-types/messages.ts +15 -0
  379. package/src/daemon/message-types/schedules.ts +11 -27
  380. package/src/daemon/message-types/sessions.ts +8 -2
  381. package/src/daemon/message-types/settings.ts +1 -1
  382. package/src/daemon/message-types/shared.ts +1 -1
  383. package/src/daemon/message-types/surfaces.ts +2 -0
  384. package/src/daemon/ride-shotgun-handler.ts +35 -43
  385. package/src/daemon/seed-files.ts +3 -27
  386. package/src/daemon/server.ts +45 -28
  387. package/src/daemon/session-agent-loop-handlers.ts +72 -9
  388. package/src/daemon/session-agent-loop.ts +97 -66
  389. package/src/daemon/session-attachments.ts +1 -1
  390. package/src/daemon/session-error.ts +17 -16
  391. package/src/daemon/session-lifecycle.ts +20 -1
  392. package/src/daemon/session-media-retry.ts +1 -15
  393. package/src/daemon/session-messaging.ts +14 -6
  394. package/src/daemon/session-process.ts +36 -7
  395. package/src/daemon/session-queue-manager.ts +62 -103
  396. package/src/daemon/session-runtime-assembly.ts +27 -7
  397. package/src/daemon/session-skill-tools.ts +12 -11
  398. package/src/daemon/session-slash.ts +7 -0
  399. package/src/daemon/session-surfaces.ts +192 -118
  400. package/src/daemon/session-tool-setup.ts +146 -6
  401. package/src/daemon/session.ts +75 -37
  402. package/src/errors.ts +0 -2
  403. package/src/export/formatter.ts +6 -0
  404. package/src/mcp/mcp-oauth-provider.ts +1 -3
  405. package/src/media/avatar-router.ts +20 -28
  406. package/src/media/avatar-types.ts +7 -14
  407. package/src/media/managed-avatar-client.ts +70 -34
  408. package/src/memory/app-store.ts +0 -18
  409. package/src/memory/conversation-title-service.ts +1 -2
  410. package/src/memory/db-init.ts +16 -0
  411. package/src/memory/embedding-backend.ts +129 -27
  412. package/src/memory/embedding-gemini.test.ts +256 -0
  413. package/src/memory/embedding-gemini.ts +47 -13
  414. package/src/memory/embedding-local.ts +14 -2
  415. package/src/memory/embedding-ollama.ts +15 -2
  416. package/src/memory/embedding-openai.ts +15 -2
  417. package/src/memory/embedding-types.test.ts +116 -0
  418. package/src/memory/embedding-types.ts +61 -0
  419. package/src/memory/fingerprint.ts +1 -1
  420. package/src/memory/indexer.ts +25 -1
  421. package/src/memory/job-handlers/embedding.test.ts +258 -0
  422. package/src/memory/job-handlers/embedding.ts +81 -1
  423. package/src/memory/job-handlers/index-maintenance.ts +35 -1
  424. package/src/memory/job-handlers/media-processing.ts +11 -1
  425. package/src/memory/job-utils.ts +21 -6
  426. package/src/memory/jobs-store.ts +5 -1
  427. package/src/memory/jobs-worker.ts +8 -0
  428. package/src/memory/message-content.ts +66 -0
  429. package/src/memory/migrations/100-core-tables.ts +1 -31
  430. package/src/memory/migrations/104-core-indexes.ts +0 -11
  431. package/src/memory/migrations/145-drop-accounts-table.ts +19 -0
  432. package/src/memory/migrations/146-schedule-oneshot-routing.ts +94 -0
  433. package/src/memory/migrations/147-migrate-reminders-to-schedules.ts +129 -0
  434. package/src/memory/migrations/148-drop-reminders-table.ts +18 -0
  435. package/src/memory/migrations/index.ts +4 -0
  436. package/src/memory/migrations/registry.ts +19 -0
  437. package/src/memory/qdrant-client.ts +158 -43
  438. package/src/memory/retriever.test.ts +0 -1
  439. package/src/memory/retriever.ts +12 -2
  440. package/src/memory/schema/infrastructure.ts +5 -37
  441. package/src/memory/search/formatting.ts +34 -9
  442. package/src/memory/search/semantic.ts +57 -2
  443. package/src/memory/search/types.ts +2 -1
  444. package/src/notifications/AGENTS.md +2 -2
  445. package/src/notifications/README.md +59 -58
  446. package/src/notifications/adapters/macos.ts +1 -1
  447. package/src/notifications/broadcaster.ts +5 -5
  448. package/src/notifications/copy-composer.ts +1 -1
  449. package/src/notifications/decision-engine.ts +2 -2
  450. package/src/notifications/destination-resolver.ts +2 -2
  451. package/src/notifications/emit-signal.ts +8 -8
  452. package/src/notifications/signal.ts +1 -1
  453. package/src/notifications/thread-seed-composer.ts +1 -1
  454. package/src/oauth/connect-orchestrator.ts +1 -1
  455. package/src/oauth/token-persistence.ts +1 -1
  456. package/src/permissions/checker.ts +12 -1
  457. package/src/permissions/defaults.ts +13 -17
  458. package/src/permissions/trust-store.ts +37 -0
  459. package/src/permissions/workspace-policy.ts +0 -1
  460. package/src/prompts/__tests__/build-cli-reference-section.test.ts +11 -0
  461. package/src/prompts/computer-use-prompt.ts +1 -1
  462. package/src/prompts/system-prompt.ts +33 -35
  463. package/src/prompts/templates/BOOTSTRAP.md +0 -3
  464. package/src/prompts/templates/SOUL.md +1 -2
  465. package/src/prompts/templates/UPDATES.md +16 -7
  466. package/src/providers/anthropic/client.ts +87 -33
  467. package/src/providers/gemini/client.ts +6 -0
  468. package/src/providers/managed-proxy/constants.ts +5 -0
  469. package/src/providers/openai/client.ts +15 -0
  470. package/src/providers/registry.ts +4 -6
  471. package/src/providers/types.ts +24 -2
  472. package/src/runtime/AGENTS.md +18 -0
  473. package/src/runtime/assistant-event-hub.ts +2 -3
  474. package/src/runtime/assistant-event.ts +4 -4
  475. package/src/runtime/auth/__tests__/context.test.ts +5 -5
  476. package/src/runtime/auth/__tests__/credential-service.test.ts +0 -1
  477. package/src/runtime/auth/__tests__/guard-tests.test.ts +3 -2
  478. package/src/runtime/auth/__tests__/{ipc-auth-context.test.ts → local-auth-context.test.ts} +21 -21
  479. package/src/runtime/auth/__tests__/route-policy.test.ts +2 -2
  480. package/src/runtime/auth/__tests__/scopes.test.ts +9 -8
  481. package/src/runtime/auth/__tests__/subject.test.ts +8 -8
  482. package/src/runtime/auth/__tests__/token-service.test.ts +0 -1
  483. package/src/runtime/auth/route-policy.ts +8 -8
  484. package/src/runtime/auth/scopes.ts +2 -1
  485. package/src/runtime/auth/subject.ts +4 -4
  486. package/src/runtime/auth/token-service.ts +1 -24
  487. package/src/runtime/auth/types.ts +3 -3
  488. package/src/runtime/guardian-action-followup-executor.ts +1 -1
  489. package/src/runtime/guardian-action-grant-minter.ts +1 -1
  490. package/src/runtime/guardian-action-service.ts +3 -3
  491. package/src/runtime/http-server.ts +15 -2
  492. package/src/runtime/http-types.ts +10 -0
  493. package/src/runtime/invite-service.ts +3 -3
  494. package/src/runtime/local-actor-identity.ts +17 -22
  495. package/src/runtime/middleware/error-handler.ts +14 -1
  496. package/src/runtime/pending-interactions.ts +21 -9
  497. package/src/runtime/routes/app-management-routes.ts +63 -67
  498. package/src/runtime/routes/approval-routes.ts +1 -3
  499. package/src/runtime/routes/brain-graph/brain-graph.html +1845 -0
  500. package/src/runtime/routes/brain-graph-routes.ts +4 -42
  501. package/src/runtime/routes/btw-routes.ts +155 -0
  502. package/src/runtime/routes/computer-use-routes.ts +77 -31
  503. package/src/runtime/routes/conversation-routes.ts +234 -47
  504. package/src/runtime/routes/diagnostics-routes.ts +154 -43
  505. package/src/runtime/routes/documents-routes.ts +2 -2
  506. package/src/runtime/routes/global-search-routes.ts +1 -1
  507. package/src/runtime/routes/host-bash-routes.ts +83 -0
  508. package/src/runtime/routes/host-file-routes.ts +79 -0
  509. package/src/runtime/routes/integrations/slack/share.ts +1 -1
  510. package/src/runtime/routes/log-export-routes.ts +120 -0
  511. package/src/runtime/routes/mcp-routes.ts +20 -0
  512. package/src/runtime/routes/migration-routes.ts +3 -3
  513. package/src/runtime/routes/pairing-routes.ts +1 -1
  514. package/src/runtime/routes/recording-routes.ts +6 -4
  515. package/src/runtime/routes/schedule-routes.ts +31 -5
  516. package/src/runtime/routes/session-management-routes.ts +2 -6
  517. package/src/runtime/routes/session-query-routes.ts +18 -15
  518. package/src/runtime/routes/settings-routes.ts +7 -351
  519. package/src/runtime/routes/skills-routes.ts +7 -6
  520. package/src/runtime/routes/subagents-routes.ts +4 -10
  521. package/src/runtime/routes/surface-action-routes.ts +3 -14
  522. package/src/runtime/routes/surface-content-routes.ts +22 -5
  523. package/src/runtime/routes/work-items-routes.ts +21 -25
  524. package/src/runtime/routes/workspace-routes.test.ts +3 -3
  525. package/src/runtime/routes/workspace-utils.ts +1 -1
  526. package/src/runtime/telegram-streaming-delivery.ts +3 -0
  527. package/src/runtime/verification-outbound-actions.ts +2 -2
  528. package/src/schedule/integration-status.ts +0 -6
  529. package/src/schedule/schedule-store.ts +234 -43
  530. package/src/schedule/scheduler.ts +73 -74
  531. package/src/security/oauth2.ts +1 -1
  532. package/src/sequence/store.ts +12 -2
  533. package/src/skills/frontmatter.ts +19 -77
  534. package/src/skills/managed-store.ts +11 -2
  535. package/src/subagent/manager.ts +5 -3
  536. package/src/tasks/ephemeral-permissions.ts +3 -5
  537. package/src/tools/AGENTS.md +37 -0
  538. package/src/tools/apps/executors.ts +0 -6
  539. package/src/tools/browser/browser-manager.ts +17 -11
  540. package/src/tools/browser/jit-auth.ts +4 -1
  541. package/src/tools/claude-code/claude-code.ts +1 -1
  542. package/src/tools/computer-use/definitions.ts +48 -60
  543. package/src/tools/document/document-tool.ts +6 -6
  544. package/src/tools/document/editor-template.ts +10 -8
  545. package/src/tools/filesystem/edit.ts +2 -1
  546. package/src/tools/filesystem/read.ts +20 -2
  547. package/src/tools/filesystem/write.ts +2 -1
  548. package/src/tools/host-filesystem/edit.ts +17 -1
  549. package/src/tools/host-filesystem/read.ts +16 -1
  550. package/src/tools/host-filesystem/write.ts +15 -1
  551. package/src/tools/host-terminal/host-shell.ts +24 -0
  552. package/src/tools/memory/definitions.ts +45 -81
  553. package/src/tools/memory/handlers.test.ts +0 -1
  554. package/src/tools/memory/handlers.ts +1 -1
  555. package/src/tools/memory/register.ts +26 -60
  556. package/src/tools/network/script-proxy/session-manager.ts +6 -8
  557. package/src/tools/network/web-fetch.ts +7 -1
  558. package/src/tools/network/web-search.ts +2 -1
  559. package/src/tools/registry.ts +23 -0
  560. package/src/tools/schedule/create.ts +113 -5
  561. package/src/tools/schedule/list.ts +57 -15
  562. package/src/tools/schedule/update.ts +73 -3
  563. package/src/tools/shared/filesystem/image-read.ts +192 -0
  564. package/src/tools/side-effects.ts +1 -7
  565. package/src/tools/skills/delete-managed.ts +27 -64
  566. package/src/tools/skills/execute.ts +54 -0
  567. package/src/tools/skills/load.ts +127 -5
  568. package/src/tools/skills/scaffold-managed.ts +93 -172
  569. package/src/tools/subagent/message.ts +0 -7
  570. package/src/tools/subagent/spawn.ts +1 -1
  571. package/src/tools/swarm/delegate.ts +0 -3
  572. package/src/tools/system/avatar-generator.ts +13 -19
  573. package/src/tools/system/request-permission.ts +2 -1
  574. package/src/tools/terminal/safe-env.ts +1 -0
  575. package/src/tools/tool-manifest.ts +41 -47
  576. package/src/tools/types.ts +6 -2
  577. package/src/tools/ui-surface/definitions.ts +0 -55
  578. package/src/util/errors.ts +12 -10
  579. package/src/workspace/git-service.ts +0 -2
  580. package/src/__tests__/account-registry.test.ts +0 -258
  581. package/src/__tests__/email-classifier.test.ts +0 -25
  582. package/src/__tests__/gmail-integration.test.ts +0 -97
  583. package/src/__tests__/handle-user-message-secret-resume.test.ts +0 -172
  584. package/src/__tests__/home-base-bootstrap.test.ts +0 -84
  585. package/src/__tests__/managed-twitter-guardrails.test.ts +0 -353
  586. package/src/__tests__/prebuilt-home-base-seed.test.ts +0 -79
  587. package/src/__tests__/recording-intent-fallback.test.ts +0 -199
  588. package/src/__tests__/recording-intent.test.ts +0 -985
  589. package/src/__tests__/recording-state-machine.test.ts +0 -1574
  590. package/src/__tests__/reminder-store.test.ts +0 -350
  591. package/src/__tests__/reminder.test.ts +0 -337
  592. package/src/__tests__/scan-result-store.test.ts +0 -121
  593. package/src/__tests__/twitter-platform-proxy-client.test.ts +0 -450
  594. package/src/__tests__/view-image-tool.test.ts +0 -241
  595. package/src/cli/commands/amazon/cart.ts +0 -513
  596. package/src/cli/commands/amazon/checkout.ts +0 -394
  597. package/src/cli/commands/amazon/client.ts +0 -513
  598. package/src/cli/commands/amazon/index.ts +0 -920
  599. package/src/cli/commands/amazon/product-details.ts +0 -145
  600. package/src/cli/commands/amazon/request-extractor.ts +0 -187
  601. package/src/cli/commands/amazon/search.ts +0 -76
  602. package/src/cli/commands/amazon/session.ts +0 -116
  603. package/src/cli/commands/twitter/__tests__/cli-error-shaping.test.ts +0 -265
  604. package/src/cli/commands/twitter/__tests__/cli-read-routing.test.ts +0 -483
  605. package/src/cli/commands/twitter/__tests__/cli-routing.test.ts +0 -412
  606. package/src/cli/commands/twitter/__tests__/oauth-client.test.ts +0 -197
  607. package/src/cli/commands/twitter/client.ts +0 -989
  608. package/src/cli/commands/twitter/index.ts +0 -1160
  609. package/src/cli/commands/twitter/oauth-client.ts +0 -94
  610. package/src/cli/commands/twitter/router.ts +0 -396
  611. package/src/cli/commands/twitter/session.ts +0 -121
  612. package/src/config/bundled-skills/agentmail/SKILL.md +0 -132
  613. package/src/config/bundled-skills/agentmail/icon.svg +0 -21
  614. package/src/config/bundled-skills/amazon/SKILL.md +0 -137
  615. package/src/config/bundled-skills/amazon/icon.svg +0 -13
  616. package/src/config/bundled-skills/api-mapping/SKILL.md +0 -78
  617. package/src/config/bundled-skills/api-mapping/icon.svg +0 -18
  618. package/src/config/bundled-skills/cli-discover/SKILL.md +0 -68
  619. package/src/config/bundled-skills/deploy-fullstack-vercel/SKILL.md +0 -179
  620. package/src/config/bundled-skills/document-writer/SKILL.md +0 -195
  621. package/src/config/bundled-skills/elevenlabs-voice/SKILL.md +0 -140
  622. package/src/config/bundled-skills/email-setup/SKILL.md +0 -68
  623. package/src/config/bundled-skills/frontend-design/SKILL.md +0 -44
  624. package/src/config/bundled-skills/frontend-design/icon.svg +0 -16
  625. package/src/config/bundled-skills/google-oauth-setup/SKILL.md +0 -452
  626. package/src/config/bundled-skills/guardian-verify-setup/SKILL.md +0 -203
  627. package/src/config/bundled-skills/influencer/SKILL.md +0 -144
  628. package/src/config/bundled-skills/influencer/scripts/client.ts +0 -1269
  629. package/src/config/bundled-skills/influencer/scripts/influencer.ts +0 -267
  630. package/src/config/bundled-skills/macos-automation/SKILL.md +0 -65
  631. package/src/config/bundled-skills/macos-automation/icon.svg +0 -12
  632. package/src/config/bundled-skills/mcp-setup/SKILL.md +0 -75
  633. package/src/config/bundled-skills/media-processing/tools/media-diagnostics.ts +0 -184
  634. package/src/config/bundled-skills/messaging/tools/gmail-archive-by-query.ts +0 -80
  635. package/src/config/bundled-skills/messaging/tools/gmail-archive.ts +0 -29
  636. package/src/config/bundled-skills/messaging/tools/gmail-batch-archive.ts +0 -56
  637. package/src/config/bundled-skills/messaging/tools/gmail-batch-label.ts +0 -34
  638. package/src/config/bundled-skills/messaging/tools/gmail-download-attachment.ts +0 -47
  639. package/src/config/bundled-skills/messaging/tools/gmail-label.ts +0 -31
  640. package/src/config/bundled-skills/messaging/tools/gmail-list-attachments.ts +0 -67
  641. package/src/config/bundled-skills/messaging/tools/gmail-send-with-attachments.ts +0 -97
  642. package/src/config/bundled-skills/messaging/tools/gmail-summarize-thread.ts +0 -87
  643. package/src/config/bundled-skills/messaging/tools/gmail-triage.ts +0 -135
  644. package/src/config/bundled-skills/messaging/tools/messaging-analyze-activity.ts +0 -24
  645. package/src/config/bundled-skills/messaging/tools/messaging-reply.ts +0 -201
  646. package/src/config/bundled-skills/messaging/tools/send-notification.ts +0 -1
  647. package/src/config/bundled-skills/messaging/tools/sequence-cancel.ts +0 -27
  648. package/src/config/bundled-skills/messaging/tools/sequence-pause.ts +0 -48
  649. package/src/config/bundled-skills/messaging/tools/sequence-resume.ts +0 -27
  650. package/src/config/bundled-skills/messaging/tools/sequence-update.ts +0 -56
  651. package/src/config/bundled-skills/notion/SKILL.md +0 -240
  652. package/src/config/bundled-skills/notion-oauth-setup/SKILL.md +0 -126
  653. package/src/config/bundled-skills/oauth-setup/SKILL.md +0 -143
  654. package/src/config/bundled-skills/public-ingress/SKILL.md +0 -258
  655. package/src/config/bundled-skills/reminder/SKILL.md +0 -79
  656. package/src/config/bundled-skills/reminder/TOOLS.json +0 -89
  657. package/src/config/bundled-skills/reminder/tools/reminder-list.ts +0 -12
  658. package/src/config/bundled-skills/restaurant-reservation/SKILL.md +0 -141
  659. package/src/config/bundled-skills/screen-recording/SKILL.md +0 -148
  660. package/src/config/bundled-skills/self-upgrade/SKILL.md +0 -69
  661. package/src/config/bundled-skills/skills-catalog/SKILL.md +0 -78
  662. package/src/config/bundled-skills/slack-app-setup/SKILL.md +0 -178
  663. package/src/config/bundled-skills/slack-digest-setup/SKILL.md +0 -163
  664. package/src/config/bundled-skills/slack-oauth-setup/SKILL.md +0 -157
  665. package/src/config/bundled-skills/start-the-day/SKILL.md +0 -70
  666. package/src/config/bundled-skills/start-the-day/icon.svg +0 -13
  667. package/src/config/bundled-skills/telegram-setup/SKILL.md +0 -105
  668. package/src/config/bundled-skills/time-based-actions/SKILL.md +0 -142
  669. package/src/config/bundled-skills/twilio-setup/SKILL.md +0 -232
  670. package/src/config/bundled-skills/twitter/SKILL.md +0 -319
  671. package/src/config/bundled-skills/twitter/icon.svg +0 -14
  672. package/src/config/bundled-skills/typescript-eval/SKILL.md +0 -60
  673. package/src/config/bundled-skills/vercel-token-setup/SKILL.md +0 -214
  674. package/src/config/bundled-skills/voice-setup/SKILL.md +0 -131
  675. package/src/config/bundled-skills/voice-setup/icon.svg +0 -20
  676. package/src/daemon/handlers/pairing.ts +0 -119
  677. package/src/daemon/handlers/session-user-message.ts +0 -961
  678. package/src/daemon/recording-executor.ts +0 -180
  679. package/src/daemon/recording-intent-fallback.ts +0 -162
  680. package/src/daemon/recording-intent.ts +0 -493
  681. package/src/home-base/app-link-store.ts +0 -78
  682. package/src/home-base/bootstrap.ts +0 -74
  683. package/src/home-base/prebuilt/brain-graph.html +0 -1483
  684. package/src/home-base/prebuilt/index.html +0 -702
  685. package/src/home-base/prebuilt/seed-metadata.json +0 -21
  686. package/src/home-base/prebuilt/seed.ts +0 -122
  687. package/src/home-base/prebuilt-home-base-updater.ts +0 -36
  688. package/src/memory/account-store.ts +0 -117
  689. package/src/messaging/activity-analyzer.ts +0 -76
  690. package/src/messaging/email-classifier.ts +0 -208
  691. package/src/messaging/index.ts +0 -2
  692. package/src/messaging/outreach-classifier.ts +0 -185
  693. package/src/messaging/thread-summarizer.ts +0 -346
  694. package/src/messaging/types.ts +0 -17
  695. package/src/tools/browser/x-auto-navigate.ts +0 -254
  696. package/src/tools/credentials/account-registry.ts +0 -144
  697. package/src/tools/filesystem/view-image.ts +0 -244
  698. package/src/tools/reminder/reminder-store.ts +0 -194
  699. package/src/tools/reminder/reminder.ts +0 -158
  700. package/src/tools/system/navigate-settings.ts +0 -74
  701. package/src/tools/system/open-system-settings.ts +0 -85
  702. package/src/tools/system/version.ts +0 -54
  703. package/src/twitter/platform-proxy-client.ts +0 -405
  704. package/src/util/cookie-session.ts +0 -98
  705. /package/src/config/bundled-skills/{messaging → gmail}/tools/scan-result-store.ts +0 -0
  706. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-analytics.ts +0 -0
  707. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-create.ts +0 -0
  708. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-delete.ts +0 -0
  709. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-enroll.ts +0 -0
  710. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-enrollment-list.ts +0 -0
  711. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-get.ts +0 -0
  712. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-import.ts +0 -0
  713. /package/src/config/bundled-skills/{messaging → sequences}/tools/sequence-list.ts +0 -0
@@ -39,7 +39,6 @@ mock.module("../util/platform.js", () => ({
39
39
  getWorkspacePromptPath: (file: string) => `/tmp/workspace/${file}`,
40
40
  getPlatformName: () => "linux",
41
41
  getClipboardCommand: () => null,
42
- getSocketPath: () => "/tmp/test.sock",
43
42
  getPidPath: () => "/tmp/test.pid",
44
43
  getDbPath: () => "/tmp/data/db/assistant.db",
45
44
  getLogPath: () => "/tmp/test.log",
@@ -75,11 +74,8 @@ mock.module("../config/loader.js", () => ({
75
74
  contextWindow: {
76
75
  enabled: true,
77
76
  maxInputTokens: 180000,
78
- targetInputTokens: 110000,
79
- compactThreshold: 0.8,
80
- preserveRecentUserTurns: 8,
81
- summaryMaxTokens: 1200,
82
- chunkTokens: 12000,
77
+ targetBudgetRatio: 0.30,
78
+ compactThreshold: 0.8, summaryBudgetRatio: 0.05,
83
79
  },
84
80
  assistantFeatureFlagValues: {},
85
81
  }),
@@ -15,11 +15,8 @@ mock.module("../config/loader.js", () => ({
15
15
  contextWindow: {
16
16
  enabled: true,
17
17
  maxInputTokens: 180000,
18
- targetInputTokens: 110000,
19
- compactThreshold: 0.8,
20
- preserveRecentUserTurns: 8,
21
- summaryMaxTokens: 1200,
22
- chunkTokens: 12000,
18
+ targetBudgetRatio: 0.30,
19
+ compactThreshold: 0.8, summaryBudgetRatio: 0.05,
23
20
  },
24
21
  }),
25
22
  invalidateConfigCache: () => {},
@@ -4,12 +4,10 @@ import {
4
4
  allComputerUseTools,
5
5
  computerUseClickTool,
6
6
  computerUseDoneTool,
7
- computerUseDoubleClickTool,
8
7
  computerUseDragTool,
9
8
  computerUseKeyTool,
10
9
  computerUseOpenAppTool,
11
10
  computerUseRespondTool,
12
- computerUseRightClickTool,
13
11
  computerUseRunAppleScriptTool,
14
12
  computerUseScrollTool,
15
13
  computerUseTypeTextTool,
@@ -42,8 +40,8 @@ const ctx: ToolContext = {
42
40
  // ── Tool definitions ────────────────────────────────────────────────
43
41
 
44
42
  describe("computer-use tool definitions", () => {
45
- test("allComputerUseTools contains 12 tools", () => {
46
- expect(allComputerUseTools.length).toBe(12);
43
+ test("allComputerUseTools contains 10 tools", () => {
44
+ expect(allComputerUseTools.length).toBe(10);
47
45
  });
48
46
 
49
47
  test("all tools have proxy execution mode", () => {
@@ -72,33 +70,39 @@ describe("computer-use tool definitions", () => {
72
70
  });
73
71
  });
74
72
 
75
- // ── Click tool variants ─────────────────────────────────────────────
76
-
77
- describe("click tool variants", () => {
78
- for (const [tool, label] of [
79
- [computerUseClickTool, "click"],
80
- [computerUseDoubleClickTool, "double_click"],
81
- [computerUseRightClickTool, "right_click"],
82
- ] as const) {
83
- test(`${tool.name} has correct name`, () => {
84
- expect(tool.name).toBe(`computer_use_${label}`);
85
- });
86
-
87
- test(`${tool.name} schema requires reasoning`, () => {
88
- expect(schema(tool).required).toContain("reasoning");
89
- });
90
-
91
- test(`${tool.name} schema supports element_id and coordinates`, () => {
92
- const props = schema(tool).properties as Record<string, { type: string }>;
93
- expect(props.element_id.type).toBe("integer");
94
- expect(props.x.type).toBe("integer");
95
- expect(props.y.type).toBe("integer");
96
- });
97
-
98
- test(`${tool.name} execute throws proxy error`, () => {
99
- expect(() => tool.execute({}, ctx)).toThrow("Proxy tool");
100
- });
101
- }
73
+ // ── Unified click tool ──────────────────────────────────────────────
74
+
75
+ describe("computer_use_click (unified)", () => {
76
+ test("has correct name", () => {
77
+ expect(computerUseClickTool.name).toBe("computer_use_click");
78
+ });
79
+
80
+ test("schema requires reasoning", () => {
81
+ expect(schema(computerUseClickTool).required).toContain("reasoning");
82
+ });
83
+
84
+ test("schema supports click_type enum", () => {
85
+ const props = schema(computerUseClickTool).properties as Record<
86
+ string,
87
+ { type: string; enum?: string[] }
88
+ >;
89
+ expect(props.click_type.type).toBe("string");
90
+ expect(props.click_type.enum).toEqual(["single", "double", "right"]);
91
+ });
92
+
93
+ test("schema supports element_id and coordinates", () => {
94
+ const props = schema(computerUseClickTool).properties as Record<
95
+ string,
96
+ { type: string }
97
+ >;
98
+ expect(props.element_id.type).toBe("integer");
99
+ expect(props.x.type).toBe("integer");
100
+ expect(props.y.type).toBe("integer");
101
+ });
102
+
103
+ test("execute throws proxy error", () => {
104
+ expect(() => computerUseClickTool.execute({}, ctx)).toThrow("Proxy tool");
105
+ });
102
106
  });
103
107
 
104
108
  // ── type_text ───────────────────────────────────────────────────────
@@ -97,11 +97,9 @@ describe("AssistantConfigSchema", () => {
97
97
  expect(result.contextWindow).toEqual({
98
98
  enabled: true,
99
99
  maxInputTokens: 200000,
100
- targetInputTokens: 110000,
100
+ targetBudgetRatio: 0.3,
101
101
  compactThreshold: 0.8,
102
- preserveRecentUserTurns: 8,
103
- summaryMaxTokens: 1200,
104
- chunkTokens: 12000,
102
+ summaryBudgetRatio: 0.05,
105
103
  overflowRecovery: {
106
104
  enabled: true,
107
105
  safetyMarginRatio: 0.05,
@@ -322,18 +320,18 @@ describe("AssistantConfigSchema", () => {
322
320
  }
323
321
  });
324
322
 
325
- test("rejects contextWindow targetInputTokens >= maxInputTokens", () => {
323
+ test("rejects contextWindow targetBudgetRatio >= compactThreshold", () => {
326
324
  const result = AssistantConfigSchema.safeParse({
327
- contextWindow: { maxInputTokens: 1000, targetInputTokens: 1000 },
325
+ contextWindow: { targetBudgetRatio: 0.8, compactThreshold: 0.8 },
328
326
  });
329
327
  expect(result.success).toBe(false);
330
328
  if (!result.success) {
331
329
  expect(
332
330
  result.error.issues.some(
333
331
  (issue) =>
334
- issue.path.join(".") === "contextWindow.targetInputTokens" &&
332
+ issue.path.join(".") === "contextWindow.targetBudgetRatio" &&
335
333
  issue.message.includes(
336
- "must be less than contextWindow.maxInputTokens",
334
+ "must be less than contextWindow.compactThreshold",
337
335
  ),
338
336
  ),
339
337
  ).toBe(true);
@@ -1102,11 +1100,9 @@ describe("loadConfig with schema validation", () => {
1102
1100
  expect(config.contextWindow).toEqual({
1103
1101
  enabled: true,
1104
1102
  maxInputTokens: 200000,
1105
- targetInputTokens: 110000,
1103
+ targetBudgetRatio: 0.3,
1106
1104
  compactThreshold: 0.8,
1107
- preserveRecentUserTurns: 8,
1108
- summaryMaxTokens: 1200,
1109
- chunkTokens: 12000,
1105
+ summaryBudgetRatio: 0.05,
1110
1106
  overflowRecovery: {
1111
1107
  enabled: true,
1112
1108
  safetyMarginRatio: 0.05,
@@ -1196,11 +1192,11 @@ describe("loadConfig with schema validation", () => {
1196
1192
 
1197
1193
  test("falls back for invalid contextWindow relationship", () => {
1198
1194
  writeConfig({
1199
- contextWindow: { maxInputTokens: 1000, targetInputTokens: 1000 },
1195
+ contextWindow: { targetBudgetRatio: 0.8, compactThreshold: 0.8 },
1200
1196
  });
1201
1197
  const config = loadConfig();
1202
- expect(config.contextWindow.maxInputTokens).toBe(200000);
1203
- expect(config.contextWindow.targetInputTokens).toBe(110000);
1198
+ expect(config.contextWindow.targetBudgetRatio).toBe(0.3);
1199
+ expect(config.contextWindow.compactThreshold).toBe(0.8);
1204
1200
  });
1205
1201
 
1206
1202
  test("falls back for invalid rateLimit values", () => {
@@ -33,7 +33,6 @@ mock.module("../util/platform.js", () => ({
33
33
  getWorkspacePromptPath: (file: string) => join(WORKSPACE_DIR, file),
34
34
  ensureDataDir: () => {},
35
35
  getDataDir: () => join(WORKSPACE_DIR, "data"),
36
- getSocketPath: () => join(TEST_DIR, "vellum.sock"),
37
36
  getPidPath: () => join(TEST_DIR, "vellum.pid"),
38
37
  getDbPath: () => join(WORKSPACE_DIR, "data", "assistant.db"),
39
38
  getLogPath: () => join(WORKSPACE_DIR, "data", "logs", "vellum.log"),
@@ -20,7 +20,6 @@ mock.module("../util/platform.js", () => ({
20
20
  isMacOS: () => process.platform === "darwin",
21
21
  isLinux: () => process.platform === "linux",
22
22
  isWindows: () => process.platform === "win32",
23
- getSocketPath: () => join(testDir, "test.sock"),
24
23
  getPidPath: () => join(testDir, "test.pid"),
25
24
  getDbPath: () => join(testDir, "test.db"),
26
25
  getLogPath: () => join(testDir, "test.log"),
@@ -12,7 +12,6 @@ mock.module("../util/platform.js", () => ({
12
12
  isMacOS: () => process.platform === "darwin",
13
13
  isLinux: () => process.platform === "linux",
14
14
  isWindows: () => process.platform === "win32",
15
- getSocketPath: () => join(testDir, "test.sock"),
16
15
  getPidPath: () => join(testDir, "test.pid"),
17
16
  getDbPath: () => join(testDir, "test.db"),
18
17
  getLogPath: () => join(testDir, "test.log"),
@@ -51,7 +51,6 @@ describe("hasNoAuthOverride", () => {
51
51
  test("returns false when VELLUM_DAEMON_NOAUTH is true without safety gate", () => {
52
52
  expect(hasNoAuthOverride({ VELLUM_DAEMON_NOAUTH: "true" })).toBe(false);
53
53
  });
54
-
55
54
  });
56
55
 
57
56
  describe("shouldAutoStartDaemon", () => {
@@ -60,15 +59,13 @@ describe("shouldAutoStartDaemon", () => {
60
59
  });
61
60
 
62
61
  test("returns true when VELLUM_DAEMON_AUTOSTART=1", () => {
63
- expect(
64
- shouldAutoStartDaemon({ VELLUM_DAEMON_AUTOSTART: "1" }),
65
- ).toBe(true);
62
+ expect(shouldAutoStartDaemon({ VELLUM_DAEMON_AUTOSTART: "1" })).toBe(true);
66
63
  });
67
64
 
68
65
  test("returns true when VELLUM_DAEMON_AUTOSTART=true", () => {
69
- expect(
70
- shouldAutoStartDaemon({ VELLUM_DAEMON_AUTOSTART: "true" }),
71
- ).toBe(true);
66
+ expect(shouldAutoStartDaemon({ VELLUM_DAEMON_AUTOSTART: "true" })).toBe(
67
+ true,
68
+ );
72
69
  });
73
70
 
74
71
  test("returns false when VELLUM_DAEMON_AUTOSTART=0", () => {
@@ -21,7 +21,6 @@ mock.module("../util/platform.js", () => ({
21
21
  isMacOS: () => process.platform === "darwin",
22
22
  isLinux: () => process.platform === "linux",
23
23
  isWindows: () => process.platform === "win32",
24
- getSocketPath: () => join(testDir, "test.sock"),
25
24
  getPidPath: () => join(testDir, "test.pid"),
26
25
  getDbPath: () => join(testDir, "test.db"),
27
26
  getLogPath: () => join(testDir, "test.log"),
@@ -36,7 +36,6 @@ mock.module("../util/platform.js", () => ({
36
36
  isMacOS: () => process.platform === "darwin",
37
37
  isLinux: () => process.platform === "linux",
38
38
  isWindows: () => process.platform === "win32",
39
- getSocketPath: () => join(testDir, "test.sock"),
40
39
  getPidPath: () => join(testDir, "test.pid"),
41
40
  getDbPath: () => join(testDir, "test.db"),
42
41
  getLogPath: () => join(testDir, "test.log"),
@@ -430,10 +429,9 @@ describe("Context + Memory E2E regression", () => {
430
429
  config: {
431
430
  ...DEFAULT_CONFIG.contextWindow,
432
431
  maxInputTokens: 5200,
433
- targetInputTokens: 2600,
432
+ targetBudgetRatio: 0.55,
434
433
  compactThreshold: 0.55,
435
- preserveRecentUserTurns: 6,
436
- chunkTokens: 900,
434
+ summaryBudgetRatio: 0.05,
437
435
  },
438
436
  });
439
437
 
@@ -57,11 +57,9 @@ function makeConfig(overrides?: Partial<ReducerConfig>): ReducerConfig {
57
57
  contextWindow: {
58
58
  enabled: true,
59
59
  maxInputTokens: 2000,
60
- targetInputTokens: 1200,
60
+ targetBudgetRatio: 0.65,
61
61
  compactThreshold: 0.6,
62
- preserveRecentUserTurns: 2,
63
- summaryMaxTokens: 128,
64
- chunkTokens: 80,
62
+ summaryBudgetRatio: 0.05,
65
63
  overflowRecovery: {
66
64
  enabled: true,
67
65
  safetyMarginRatio: 0.05,
@@ -20,11 +20,9 @@ function makeConfig(
20
20
  return {
21
21
  enabled: true,
22
22
  maxInputTokens: 450,
23
- targetInputTokens: 300,
23
+ targetBudgetRatio: 0.67,
24
24
  compactThreshold: 0.6,
25
- preserveRecentUserTurns: 2,
26
- summaryMaxTokens: 128,
27
- chunkTokens: 80,
25
+ summaryBudgetRatio: 0.05,
28
26
  overflowRecovery: {
29
27
  enabled: true,
30
28
  safetyMarginRatio: 0.05,
@@ -85,7 +83,7 @@ describe("ContextWindowManager", () => {
85
83
  const manager = new ContextWindowManager({
86
84
  provider,
87
85
  systemPrompt: "system prompt",
88
- config: makeConfig(),
86
+ config: makeConfig({ maxInputTokens: 600 }),
89
87
  });
90
88
  const long = "x".repeat(240);
91
89
  const history: Message[] = [
@@ -117,28 +115,26 @@ describe("ContextWindowManager", () => {
117
115
  expect(userTexts.some((text) => text.startsWith("u3 "))).toBe(true);
118
116
  });
119
117
 
120
- test("aggregates cache-aware summary usage across compaction chunks", async () => {
121
- let summaryCalls = 0;
118
+ test("returns cache-aware summary usage from single-pass compaction", async () => {
122
119
  const provider = createProvider(() => {
123
- summaryCalls += 1;
124
120
  return {
125
121
  content: [
126
- { type: "text", text: `## Goals\n- summary chunk ${summaryCalls}` },
122
+ { type: "text", text: `## Goals\n- summary of full transcript` },
127
123
  ],
128
124
  model: "claude-opus-4-6",
129
125
  usage: {
130
- inputTokens: 1_000 + summaryCalls,
131
- outputTokens: 20 + summaryCalls,
132
- cacheCreationInputTokens: 10 * summaryCalls,
133
- cacheReadInputTokens: 100 * summaryCalls,
126
+ inputTokens: 5_000,
127
+ outputTokens: 80,
128
+ cacheCreationInputTokens: 50,
129
+ cacheReadInputTokens: 200,
134
130
  },
135
131
  rawResponse: {
136
132
  usage: {
137
133
  cache_creation: {
138
- ephemeral_5m_input_tokens: 10 * summaryCalls,
134
+ ephemeral_5m_input_tokens: 50,
139
135
  ephemeral_1h_input_tokens: 0,
140
136
  },
141
- cache_read_input_tokens: 100 * summaryCalls,
137
+ cache_read_input_tokens: 200,
142
138
  },
143
139
  },
144
140
  stopReason: "end_turn",
@@ -149,8 +145,7 @@ describe("ContextWindowManager", () => {
149
145
  systemPrompt: "system prompt",
150
146
  config: makeConfig({
151
147
  maxInputTokens: 7_000,
152
- targetInputTokens: 2_500,
153
- preserveRecentUserTurns: 1,
148
+ targetBudgetRatio: 0.41,
154
149
  }),
155
150
  });
156
151
  const long = "q".repeat(6_000);
@@ -165,19 +160,14 @@ describe("ContextWindowManager", () => {
165
160
  const result = await manager.maybeCompact(history);
166
161
 
167
162
  expect(result.compacted).toBe(true);
168
- expect(result.summaryCalls).toBe(summaryCalls);
169
- expect(result.summaryCalls).toBeGreaterThan(1);
170
- expect(result.summaryCacheCreationInputTokens).toBe(
171
- summaryCalls * (summaryCalls + 1) * 5,
172
- );
173
- expect(result.summaryCacheReadInputTokens).toBe(
174
- summaryCalls * (summaryCalls + 1) * 50,
175
- );
176
- expect(result.summaryRawResponses).toHaveLength(summaryCalls);
163
+ expect(result.summaryCalls).toBe(1);
164
+ expect(result.summaryCacheCreationInputTokens).toBe(50);
165
+ expect(result.summaryCacheReadInputTokens).toBe(200);
166
+ expect(result.summaryRawResponses).toHaveLength(1);
177
167
  expect(result.summaryRawResponses?.[0]).toMatchObject({
178
168
  usage: {
179
- cache_creation: { ephemeral_5m_input_tokens: 10 },
180
- cache_read_input_tokens: 100,
169
+ cache_creation: { ephemeral_5m_input_tokens: 50 },
170
+ cache_read_input_tokens: 200,
181
171
  },
182
172
  });
183
173
  });
@@ -194,8 +184,7 @@ describe("ContextWindowManager", () => {
194
184
  systemPrompt: "system prompt",
195
185
  config: makeConfig({
196
186
  maxInputTokens: 300,
197
- targetInputTokens: 160,
198
- preserveRecentUserTurns: 1,
187
+ targetBudgetRatio: 0.58,
199
188
  }),
200
189
  });
201
190
  const long = "y".repeat(220);
@@ -234,8 +223,7 @@ describe("ContextWindowManager", () => {
234
223
  systemPrompt: "system prompt",
235
224
  config: makeConfig({
236
225
  maxInputTokens: 260,
237
- targetInputTokens: 140,
238
- preserveRecentUserTurns: 1,
226
+ targetBudgetRatio: 0.59,
239
227
  }),
240
228
  });
241
229
  const long = "z".repeat(220);
@@ -272,12 +260,11 @@ describe("ContextWindowManager", () => {
272
260
  provider,
273
261
  systemPrompt: "system prompt",
274
262
  config: makeConfig({
275
- maxInputTokens: 280,
276
- targetInputTokens: 150,
277
- preserveRecentUserTurns: 1,
263
+ maxInputTokens: 550,
264
+ targetBudgetRatio: 0.59,
278
265
  }),
279
266
  });
280
- const long = "f".repeat(220);
267
+ const long = "f".repeat(500);
281
268
  const history: Message[] = [
282
269
  {
283
270
  role: "user",
@@ -322,8 +309,7 @@ describe("ContextWindowManager", () => {
322
309
  systemPrompt: "system prompt",
323
310
  config: makeConfig({
324
311
  maxInputTokens: 320,
325
- targetInputTokens: 170,
326
- preserveRecentUserTurns: 1,
312
+ targetBudgetRatio: 0.58,
327
313
  }),
328
314
  });
329
315
  const long = "k".repeat(220);
@@ -370,8 +356,7 @@ describe("ContextWindowManager", () => {
370
356
  systemPrompt: "system prompt",
371
357
  config: makeConfig({
372
358
  maxInputTokens: 320,
373
- targetInputTokens: 170,
374
- preserveRecentUserTurns: 1,
359
+ targetBudgetRatio: 0.58,
375
360
  }),
376
361
  });
377
362
  const long = "k".repeat(220);
@@ -431,8 +416,7 @@ describe("ContextWindowManager", () => {
431
416
  systemPrompt: "system prompt",
432
417
  config: makeConfig({
433
418
  maxInputTokens: 2600,
434
- targetInputTokens: 1500,
435
- preserveRecentUserTurns: 1,
419
+ targetBudgetRatio: 0.63,
436
420
  }),
437
421
  });
438
422
  const long = "c".repeat(5000);
@@ -445,11 +429,11 @@ describe("ContextWindowManager", () => {
445
429
  const result = await manager.maybeCompact(history);
446
430
 
447
431
  expect(result.compacted).toBe(true);
448
- expect(result.summaryCalls).toBe(2);
449
- expect(result.summaryInputTokens).toBe(1000);
450
- expect(result.summaryCacheCreationInputTokens).toBe(240);
451
- expect(result.summaryCacheReadInputTokens).toBe(680);
452
- expect(result.summaryRawResponses).toEqual([rawResponse, rawResponse]);
432
+ expect(result.summaryCalls).toBe(1);
433
+ expect(result.summaryInputTokens).toBe(500);
434
+ expect(result.summaryCacheCreationInputTokens).toBe(120);
435
+ expect(result.summaryCacheReadInputTokens).toBe(340);
436
+ expect(result.summaryRawResponses).toEqual([rawResponse]);
453
437
  });
454
438
 
455
439
  test("does not parse user-authored summary marker text as internal summary", () => {
@@ -476,8 +460,7 @@ describe("ContextWindowManager", () => {
476
460
  systemPrompt: "system prompt",
477
461
  config: makeConfig({
478
462
  maxInputTokens: 260,
479
- targetInputTokens: 180,
480
- preserveRecentUserTurns: 1,
463
+ targetBudgetRatio: 0.74,
481
464
  }),
482
465
  });
483
466
  const long = "c".repeat(220);
@@ -506,8 +489,7 @@ describe("ContextWindowManager", () => {
506
489
  systemPrompt: "system prompt",
507
490
  config: makeConfig({
508
491
  maxInputTokens: 320,
509
- targetInputTokens: 180,
510
- preserveRecentUserTurns: 1,
492
+ targetBudgetRatio: 0.61,
511
493
  }),
512
494
  });
513
495
  const long = "p".repeat(340);
@@ -538,8 +520,7 @@ describe("ContextWindowManager", () => {
538
520
  systemPrompt: "system prompt",
539
521
  config: makeConfig({
540
522
  maxInputTokens: 260,
541
- targetInputTokens: 180,
542
- preserveRecentUserTurns: 1,
523
+ targetBudgetRatio: 0.74,
543
524
  }),
544
525
  });
545
526
  const long = "c".repeat(220);
@@ -572,9 +553,8 @@ describe("ContextWindowManager", () => {
572
553
  systemPrompt: "system prompt",
573
554
  config: makeConfig({
574
555
  maxInputTokens: 7000,
575
- targetInputTokens: 5000,
556
+ targetBudgetRatio: 0.76,
576
557
  compactThreshold: 0.8,
577
- preserveRecentUserTurns: 1,
578
558
  }),
579
559
  });
580
560
 
@@ -624,8 +604,7 @@ describe("ContextWindowManager", () => {
624
604
  systemPrompt: "system prompt",
625
605
  config: makeConfig({
626
606
  maxInputTokens: 260,
627
- targetInputTokens: 60,
628
- preserveRecentUserTurns: 2,
607
+ targetBudgetRatio: 0.28,
629
608
  }),
630
609
  });
631
610
  const long = "e".repeat(220);
@@ -640,7 +619,7 @@ describe("ContextWindowManager", () => {
640
619
  minKeepRecentUserTurns: 0,
641
620
  });
642
621
  expect(result.compacted).toBe(true);
643
- // With minKeepRecentUserTurns=0 and a tight targetInputTokens budget,
622
+ // With minKeepRecentUserTurns=0 and a tight target budget,
644
623
  // pickKeepBoundary drops keepTurns all the way to 0.
645
624
  // All three messages are compacted into a single summary message.
646
625
  expect(result.compactedMessages).toBe(3);
@@ -709,6 +688,115 @@ describe("ContextWindowManager", () => {
709
688
  expect(result.estimatedTokens).toBe(0);
710
689
  });
711
690
 
691
+ test("truncates tool results in kept turns to preserve more conversation", async () => {
692
+ const provider = createProvider(() => ({
693
+ content: [{ type: "text", text: "## Goals\n- truncation summary" }],
694
+ model: "mock-model",
695
+ usage: { inputTokens: 60, outputTokens: 12 },
696
+ stopReason: "end_turn",
697
+ }));
698
+ // Budget is tight enough that full 8K tool results would force dropping turns,
699
+ // but truncated results (≤6K chars) should allow more turns to be kept.
700
+ const config = makeConfig({
701
+ maxInputTokens: 4000,
702
+ targetBudgetRatio: 0.7,
703
+ });
704
+ const manager = new ContextWindowManager({
705
+ provider,
706
+ systemPrompt: "system prompt",
707
+ config,
708
+ });
709
+
710
+ const largeToolResult = "x".repeat(8000);
711
+ const history: Message[] = [
712
+ message("user", "u1"),
713
+ {
714
+ role: "assistant",
715
+ content: [
716
+ {
717
+ type: "tool_use",
718
+ id: "t1",
719
+ name: "read_file",
720
+ input: { path: "/tmp/a" },
721
+ },
722
+ ],
723
+ },
724
+ {
725
+ role: "user",
726
+ content: [
727
+ {
728
+ type: "tool_result",
729
+ tool_use_id: "t1",
730
+ content: largeToolResult,
731
+ },
732
+ ],
733
+ },
734
+ message("assistant", "a1"),
735
+ message("user", "u2"),
736
+ {
737
+ role: "assistant",
738
+ content: [
739
+ {
740
+ type: "tool_use",
741
+ id: "t2",
742
+ name: "read_file",
743
+ input: { path: "/tmp/b" },
744
+ },
745
+ ],
746
+ },
747
+ {
748
+ role: "user",
749
+ content: [
750
+ {
751
+ type: "tool_result",
752
+ tool_use_id: "t2",
753
+ content: largeToolResult,
754
+ },
755
+ ],
756
+ },
757
+ message("assistant", "a2"),
758
+ message("user", "u3"),
759
+ {
760
+ role: "assistant",
761
+ content: [
762
+ {
763
+ type: "tool_use",
764
+ id: "t3",
765
+ name: "read_file",
766
+ input: { path: "/tmp/c" },
767
+ },
768
+ ],
769
+ },
770
+ {
771
+ role: "user",
772
+ content: [
773
+ {
774
+ type: "tool_result",
775
+ tool_use_id: "t3",
776
+ content: largeToolResult,
777
+ },
778
+ ],
779
+ },
780
+ message("assistant", "a3"),
781
+ message("user", "u4"),
782
+ message("assistant", "a4"),
783
+ ];
784
+
785
+ const result = await manager.maybeCompact(history, undefined, {
786
+ force: true,
787
+ });
788
+ expect(result.compacted).toBe(true);
789
+
790
+ // Verify tool results in output are truncated (should be < 8K chars each).
791
+ for (const msg of result.messages) {
792
+ for (const block of msg.content) {
793
+ if (block.type === "tool_result") {
794
+ expect(block.content.length).toBeLessThan(8000);
795
+ }
796
+ }
797
+ }
798
+ });
799
+
712
800
  test("targetInputTokensOverride reduces retained turns beyond normal compaction", async () => {
713
801
  const provider = createProvider(() => ({
714
802
  content: [{ type: "text", text: "## Goals\n- tight fit summary" }],
@@ -720,8 +808,7 @@ describe("ContextWindowManager", () => {
720
808
  // Use generous default target so normal compaction would keep all 3 user turns.
721
809
  const config = makeConfig({
722
810
  maxInputTokens: 1200,
723
- targetInputTokens: 1000,
724
- preserveRecentUserTurns: 3,
811
+ targetBudgetRatio: 0.88,
725
812
  });
726
813
  const long = "t".repeat(220);
727
814
  const history: Message[] = [
@@ -67,7 +67,6 @@ mock.module("../util/platform.js", () => ({
67
67
  isMacOS: () => process.platform === "darwin",
68
68
  isLinux: () => process.platform === "linux",
69
69
  isWindows: () => process.platform === "win32",
70
- getSocketPath: () => join(testDir, "test.sock"),
71
70
  getPidPath: () => join(testDir, "test.pid"),
72
71
  getDbPath: () => join(testDir, "test.db"),
73
72
  getLogPath: () => join(testDir, "test.log"),
@@ -10,7 +10,6 @@ mock.module("../util/platform.js", () => ({
10
10
  isMacOS: () => process.platform === "darwin",
11
11
  isLinux: () => process.platform === "linux",
12
12
  isWindows: () => process.platform === "win32",
13
- getSocketPath: () => join(testDir, "test.sock"),
14
13
  getPidPath: () => join(testDir, "test.pid"),
15
14
  getDbPath: () => join(testDir, "test.db"),
16
15
  getLogPath: () => join(testDir, "test.log"),