@ouro.bot/cli 0.1.0-alpha.6 → 0.1.0-alpha.600

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 (440) hide show
  1. package/README.md +229 -183
  2. package/RepairGuide.ouro/agent.json +5 -0
  3. package/RepairGuide.ouro/psyche/IDENTITY.md +19 -0
  4. package/RepairGuide.ouro/psyche/SOUL.md +55 -0
  5. package/RepairGuide.ouro/skills/diagnose-broken-remote.md +63 -0
  6. package/RepairGuide.ouro/skills/diagnose-stacked-typed-issues.md +35 -0
  7. package/RepairGuide.ouro/skills/diagnose-sync-blocked.md +54 -0
  8. package/RepairGuide.ouro/skills/diagnose-vault-expired.md +60 -0
  9. package/SerpentGuide.ouro/agent.json +83 -0
  10. package/SerpentGuide.ouro/psyche/SOUL.md +25 -0
  11. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +2 -2
  12. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  13. package/assets/ouroboros.png +0 -0
  14. package/changelog.json +4182 -0
  15. package/dist/arc/attention-types.js +8 -0
  16. package/dist/arc/cares.js +140 -0
  17. package/dist/arc/episodes.js +117 -0
  18. package/dist/arc/intentions.js +133 -0
  19. package/dist/arc/json-store.js +117 -0
  20. package/dist/arc/obligations.js +254 -0
  21. package/dist/arc/packets.js +193 -0
  22. package/dist/arc/presence.js +185 -0
  23. package/dist/arc/task-lifecycle.js +65 -0
  24. package/dist/heart/active-work.js +989 -0
  25. package/dist/heart/agent-entry.js +69 -3
  26. package/dist/heart/attachments/image-normalize.js +194 -0
  27. package/dist/heart/attachments/materialize.js +97 -0
  28. package/dist/heart/attachments/originals.js +88 -0
  29. package/dist/heart/attachments/render.js +29 -0
  30. package/dist/heart/attachments/sources/adapter.js +2 -0
  31. package/dist/heart/attachments/sources/bluebubbles.js +156 -0
  32. package/dist/heart/attachments/sources/cli-local-file.js +78 -0
  33. package/dist/heart/attachments/sources/index.js +16 -0
  34. package/dist/heart/attachments/store.js +103 -0
  35. package/dist/heart/attachments/types.js +93 -0
  36. package/dist/heart/auth/auth-flow.js +479 -0
  37. package/dist/heart/awaiting/await-alert.js +146 -0
  38. package/dist/heart/awaiting/await-expiry.js +108 -0
  39. package/dist/heart/awaiting/await-loader.js +91 -0
  40. package/dist/heart/awaiting/await-parser.js +141 -0
  41. package/dist/heart/awaiting/await-runtime-state.js +97 -0
  42. package/dist/heart/awaiting/await-scheduler.js +377 -0
  43. package/dist/heart/background-operations.js +281 -0
  44. package/dist/heart/bridges/manager.js +358 -0
  45. package/dist/heart/bridges/state-machine.js +135 -0
  46. package/dist/heart/bridges/store.js +123 -0
  47. package/dist/heart/bundle-state.js +168 -0
  48. package/dist/heart/commitments.js +142 -0
  49. package/dist/heart/config-registry.js +322 -0
  50. package/dist/heart/config.js +164 -135
  51. package/dist/heart/core.js +1069 -260
  52. package/dist/heart/cross-chat-delivery.js +131 -0
  53. package/dist/heart/daemon/agent-config-check.js +419 -0
  54. package/dist/heart/daemon/agent-discovery.js +180 -0
  55. package/dist/heart/daemon/agent-service.js +522 -0
  56. package/dist/heart/daemon/agentic-repair.js +547 -0
  57. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  58. package/dist/heart/daemon/boot-sync-probe.js +197 -0
  59. package/dist/heart/daemon/cadence.js +70 -0
  60. package/dist/heart/daemon/cli-defaults.js +776 -0
  61. package/dist/heart/daemon/cli-exec.js +7571 -0
  62. package/dist/heart/daemon/cli-help.js +498 -0
  63. package/dist/heart/daemon/cli-parse.js +1599 -0
  64. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  65. package/dist/heart/daemon/cli-render.js +763 -0
  66. package/dist/heart/daemon/cli-types.js +8 -0
  67. package/dist/heart/daemon/connect-bay.js +323 -0
  68. package/dist/heart/daemon/daemon-cli.js +30 -758
  69. package/dist/heart/daemon/daemon-entry.js +540 -8
  70. package/dist/heart/daemon/daemon-health.js +176 -0
  71. package/dist/heart/daemon/daemon-rollup.js +57 -0
  72. package/dist/heart/daemon/daemon-runtime-sync.js +287 -0
  73. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  74. package/dist/heart/daemon/daemon.js +972 -20
  75. package/dist/heart/daemon/dns-workflow.js +394 -0
  76. package/dist/heart/daemon/doctor-types.js +8 -0
  77. package/dist/heart/daemon/doctor.js +873 -0
  78. package/dist/heart/daemon/health-monitor.js +122 -1
  79. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  80. package/dist/heart/daemon/hooks/bundle-meta.js +206 -0
  81. package/dist/heart/daemon/http-health-probe.js +80 -0
  82. package/dist/heart/daemon/human-command-screens.js +234 -0
  83. package/dist/heart/daemon/human-readiness.js +114 -0
  84. package/dist/heart/daemon/inner-status.js +89 -0
  85. package/dist/heart/daemon/interactive-repair.js +394 -0
  86. package/dist/heart/daemon/launchd.js +188 -0
  87. package/dist/heart/daemon/log-tailer.js +82 -12
  88. package/dist/heart/daemon/logs-prune.js +110 -0
  89. package/dist/heart/daemon/mcp-canary.js +297 -0
  90. package/dist/heart/daemon/message-router.js +17 -8
  91. package/dist/heart/daemon/os-cron-deps.js +135 -0
  92. package/dist/heart/daemon/os-cron.js +14 -12
  93. package/dist/heart/daemon/ouro-bot-entry.js +4 -2
  94. package/dist/heart/daemon/ouro-entry.js +3 -1
  95. package/dist/heart/daemon/process-manager.js +381 -26
  96. package/dist/heart/daemon/provider-discovery.js +137 -0
  97. package/dist/heart/daemon/provider-ping-progress.js +83 -0
  98. package/dist/heart/daemon/pulse.js +475 -0
  99. package/dist/heart/daemon/readiness-repair.js +365 -0
  100. package/dist/heart/daemon/run-hooks.js +39 -0
  101. package/dist/heart/daemon/runtime-logging.js +67 -16
  102. package/dist/heart/daemon/runtime-metadata.js +191 -0
  103. package/dist/heart/daemon/runtime-mode.js +67 -0
  104. package/dist/heart/daemon/safe-mode.js +161 -0
  105. package/dist/heart/daemon/sense-manager.js +731 -0
  106. package/dist/heart/daemon/session-id-resolver.js +131 -0
  107. package/dist/heart/daemon/skill-management-installer.js +94 -0
  108. package/dist/heart/daemon/socket-client.js +349 -0
  109. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  110. package/dist/heart/daemon/startup-tui.js +330 -0
  111. package/dist/heart/daemon/task-scheduler.js +3 -25
  112. package/dist/heart/daemon/terminal-ui.js +499 -0
  113. package/dist/heart/daemon/thoughts.js +524 -0
  114. package/dist/heart/daemon/up-progress.js +366 -0
  115. package/dist/heart/daemon/vault-items.js +56 -0
  116. package/dist/heart/delegation.js +62 -0
  117. package/dist/heart/habits/habit-migration.js +189 -0
  118. package/dist/heart/habits/habit-parser.js +140 -0
  119. package/dist/heart/habits/habit-runtime-state.js +100 -0
  120. package/dist/heart/habits/habit-scheduler.js +372 -0
  121. package/dist/heart/{daemon → hatch}/hatch-animation.js +10 -3
  122. package/dist/heart/{daemon → hatch}/hatch-flow.js +34 -136
  123. package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
  124. package/dist/heart/hatch/specialist-orchestrator.js +129 -0
  125. package/dist/heart/hatch/specialist-prompt.js +102 -0
  126. package/dist/heart/hatch/specialist-tools.js +306 -0
  127. package/dist/heart/identity.js +281 -67
  128. package/dist/heart/kept-notes.js +357 -0
  129. package/dist/heart/kicks.js +2 -20
  130. package/dist/heart/machine-identity.js +161 -0
  131. package/dist/heart/mail-import-discovery.js +353 -0
  132. package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
  133. package/dist/heart/mailbox/mailbox-http-response.js +7 -0
  134. package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
  135. package/dist/heart/mailbox/mailbox-http-static.js +103 -0
  136. package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
  137. package/dist/heart/mailbox/mailbox-http.js +99 -0
  138. package/dist/heart/mailbox/mailbox-read.js +31 -0
  139. package/dist/heart/mailbox/mailbox-types.js +27 -0
  140. package/dist/heart/mailbox/mailbox-view.js +195 -0
  141. package/dist/heart/mailbox/readers/agent-machine.js +382 -0
  142. package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
  143. package/dist/heart/mailbox/readers/mail.js +367 -0
  144. package/dist/heart/mailbox/readers/runtime-readers.js +651 -0
  145. package/dist/heart/mailbox/readers/sessions.js +232 -0
  146. package/dist/heart/mailbox/readers/shared.js +111 -0
  147. package/dist/heart/mcp/mcp-server.js +656 -0
  148. package/dist/heart/migrate-config.js +100 -0
  149. package/dist/heart/model-capabilities.js +59 -0
  150. package/dist/heart/platform.js +81 -0
  151. package/dist/heart/progress-story.js +42 -0
  152. package/dist/heart/provider-attempt.js +134 -0
  153. package/dist/heart/provider-binding-resolver.js +267 -0
  154. package/dist/heart/provider-credentials.js +425 -0
  155. package/dist/heart/provider-failover.js +301 -0
  156. package/dist/heart/provider-models.js +81 -0
  157. package/dist/heart/provider-ping.js +262 -0
  158. package/dist/heart/provider-readiness-cache.js +40 -0
  159. package/dist/heart/provider-visibility.js +188 -0
  160. package/dist/heart/providers/anthropic-token.js +131 -0
  161. package/dist/heart/providers/anthropic.js +202 -50
  162. package/dist/heart/providers/azure.js +104 -13
  163. package/dist/heart/providers/error-classification.js +127 -0
  164. package/dist/heart/providers/github-copilot.js +145 -0
  165. package/dist/heart/providers/minimax-vlm.js +189 -0
  166. package/dist/heart/providers/minimax.js +29 -7
  167. package/dist/heart/providers/openai-codex.js +63 -39
  168. package/dist/heart/runtime-capability-check.js +170 -0
  169. package/dist/heart/runtime-credentials.js +367 -0
  170. package/dist/heart/runtime-cwd.js +87 -0
  171. package/dist/heart/sense-truth.js +70 -0
  172. package/dist/heart/session-activity.js +190 -0
  173. package/dist/heart/session-events.js +1149 -0
  174. package/dist/heart/session-playback-cli-main.js +5 -0
  175. package/dist/heart/session-playback-cli.js +36 -0
  176. package/dist/heart/session-playback.js +231 -0
  177. package/dist/heart/session-stats-cli-main.js +5 -0
  178. package/dist/heart/session-stats.js +182 -0
  179. package/dist/heart/session-transcript.js +243 -0
  180. package/dist/heart/start-of-turn-packet.js +345 -0
  181. package/dist/heart/streaming.js +129 -34
  182. package/dist/heart/sync-classification.js +176 -0
  183. package/dist/heart/sync.js +449 -0
  184. package/dist/heart/target-resolution.js +127 -0
  185. package/dist/heart/tempo.js +93 -0
  186. package/dist/heart/temporal-view.js +41 -0
  187. package/dist/heart/timeouts.js +101 -0
  188. package/dist/heart/tool-activity-callbacks.js +59 -0
  189. package/dist/heart/tool-description.js +143 -0
  190. package/dist/heart/tool-friction.js +55 -0
  191. package/dist/heart/tool-loop.js +200 -0
  192. package/dist/heart/turn-context.js +421 -0
  193. package/dist/heart/turn-coordinator.js +28 -0
  194. package/dist/heart/versioning/ouro-bot-global-installer.js +129 -0
  195. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  196. package/dist/heart/versioning/ouro-path-installer.js +426 -0
  197. package/dist/heart/{daemon → versioning}/ouro-uti.js +11 -2
  198. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  199. package/dist/heart/versioning/staged-restart.js +146 -0
  200. package/dist/heart/versioning/update-checker.js +116 -0
  201. package/dist/heart/versioning/update-hooks.js +142 -0
  202. package/dist/heart/versioning/wrapper-publish-guard.js +86 -0
  203. package/dist/mailbox-ui/assets/index-B-461hes.js +61 -0
  204. package/dist/mailbox-ui/assets/index-BPr5vNuM.css +1 -0
  205. package/dist/mailbox-ui/index.html +15 -0
  206. package/dist/mailroom/attention.js +167 -0
  207. package/dist/mailroom/autonomy.js +209 -0
  208. package/dist/mailroom/blob-store.js +700 -0
  209. package/dist/mailroom/body-cache.js +61 -0
  210. package/dist/mailroom/core.js +788 -0
  211. package/dist/mailroom/entry.js +160 -0
  212. package/dist/mailroom/file-store.js +457 -0
  213. package/dist/mailroom/mbox-import.js +393 -0
  214. package/dist/mailroom/migration.js +164 -0
  215. package/dist/mailroom/outbound.js +380 -0
  216. package/dist/mailroom/policy.js +263 -0
  217. package/dist/mailroom/reader.js +233 -0
  218. package/dist/mailroom/search-cache.js +268 -0
  219. package/dist/mailroom/search-relevance.js +319 -0
  220. package/dist/mailroom/smtp-ingress.js +176 -0
  221. package/dist/mailroom/source-state.js +176 -0
  222. package/dist/mailroom/thread.js +109 -0
  223. package/dist/mailroom/travel-extract.js +89 -0
  224. package/dist/mind/bundle-manifest.js +77 -1
  225. package/dist/mind/context.js +174 -94
  226. package/dist/mind/diary-integrity.js +60 -0
  227. package/dist/mind/{memory.js → diary.js} +84 -96
  228. package/dist/mind/embedding-provider.js +60 -0
  229. package/dist/mind/file-state.js +179 -0
  230. package/dist/mind/first-impressions.js +16 -2
  231. package/dist/mind/friends/channel.js +74 -0
  232. package/dist/mind/friends/group-context.js +144 -0
  233. package/dist/mind/friends/resolver.js +54 -2
  234. package/dist/mind/friends/store-file.js +58 -3
  235. package/dist/mind/friends/trust-explanation.js +74 -0
  236. package/dist/mind/friends/types.js +10 -2
  237. package/dist/mind/journal-index.js +161 -0
  238. package/dist/mind/note-search.js +268 -0
  239. package/dist/mind/obligation-steering.js +221 -0
  240. package/dist/mind/pending.js +76 -9
  241. package/dist/mind/phrases.js +1 -0
  242. package/dist/mind/prompt-refresh.js +3 -2
  243. package/dist/mind/prompt.js +1267 -130
  244. package/dist/mind/provenance-trust.js +26 -0
  245. package/dist/mind/scrutiny.js +173 -0
  246. package/dist/mind/token-estimate.js +8 -12
  247. package/dist/nerves/cli-logging.js +22 -3
  248. package/dist/nerves/coverage/audit-rules.js +15 -6
  249. package/dist/nerves/coverage/audit.js +28 -2
  250. package/dist/nerves/coverage/cli.js +1 -1
  251. package/dist/nerves/coverage/contract.js +5 -5
  252. package/dist/nerves/coverage/file-completeness.js +129 -5
  253. package/dist/nerves/coverage/run-artifacts.js +1 -1
  254. package/dist/nerves/event-buffer.js +111 -0
  255. package/dist/nerves/index.js +224 -4
  256. package/dist/nerves/observation.js +20 -0
  257. package/dist/nerves/redact.js +79 -0
  258. package/dist/nerves/review/cli-main.js +5 -0
  259. package/dist/nerves/review/cli.js +156 -0
  260. package/dist/nerves/review/core.js +152 -0
  261. package/dist/nerves/runtime.js +5 -1
  262. package/dist/repertoire/ado-client.js +17 -56
  263. package/dist/repertoire/ado-semantic.js +11 -10
  264. package/dist/repertoire/api-client.js +97 -0
  265. package/dist/repertoire/bitwarden-store.js +997 -0
  266. package/dist/repertoire/bundle-templates.js +72 -0
  267. package/dist/repertoire/bw-installer.js +180 -0
  268. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  269. package/dist/repertoire/coding/context-pack.js +330 -0
  270. package/dist/repertoire/coding/feedback.js +301 -0
  271. package/dist/repertoire/coding/index.js +4 -1
  272. package/dist/repertoire/coding/manager.js +220 -13
  273. package/dist/repertoire/coding/spawner.js +58 -12
  274. package/dist/repertoire/coding/tools.js +209 -7
  275. package/dist/repertoire/commerce-errors.js +109 -0
  276. package/dist/repertoire/commerce-self-test.js +156 -0
  277. package/dist/repertoire/credential-access.js +178 -0
  278. package/dist/repertoire/data/ado-endpoints.json +188 -0
  279. package/dist/repertoire/duffel-client.js +185 -0
  280. package/dist/repertoire/github-client.js +14 -55
  281. package/dist/repertoire/graph-client.js +11 -52
  282. package/dist/repertoire/guardrails.js +396 -0
  283. package/dist/repertoire/mcp-client.js +295 -0
  284. package/dist/repertoire/mcp-manager.js +362 -0
  285. package/dist/repertoire/mcp-tools.js +63 -0
  286. package/dist/repertoire/shell-sessions.js +133 -0
  287. package/dist/repertoire/skills.js +15 -24
  288. package/dist/repertoire/stripe-client.js +131 -0
  289. package/dist/repertoire/tasks/board.js +43 -5
  290. package/dist/repertoire/tasks/fix.js +182 -0
  291. package/dist/repertoire/tasks/index.js +39 -13
  292. package/dist/repertoire/tasks/lifecycle.js +2 -2
  293. package/dist/repertoire/tasks/parser.js +3 -2
  294. package/dist/repertoire/tasks/scanner.js +194 -37
  295. package/dist/repertoire/tasks/transitions.js +16 -79
  296. package/dist/repertoire/tool-results.js +29 -0
  297. package/dist/repertoire/tools-attachments.js +317 -0
  298. package/dist/repertoire/tools-awaiting.js +360 -0
  299. package/dist/repertoire/tools-base.js +56 -707
  300. package/dist/repertoire/tools-bluebubbles.js +94 -0
  301. package/dist/repertoire/tools-bridge.js +142 -0
  302. package/dist/repertoire/tools-bundle.js +984 -0
  303. package/dist/repertoire/tools-config.js +185 -0
  304. package/dist/repertoire/tools-continuity.js +248 -0
  305. package/dist/repertoire/tools-credential.js +381 -0
  306. package/dist/repertoire/tools-files.js +342 -0
  307. package/dist/repertoire/tools-flight.js +224 -0
  308. package/dist/repertoire/tools-flow.js +119 -0
  309. package/dist/repertoire/tools-github.js +1 -7
  310. package/dist/repertoire/tools-mail.js +1916 -0
  311. package/dist/repertoire/tools-notes.js +421 -0
  312. package/dist/repertoire/tools-obligations.js +142 -0
  313. package/dist/repertoire/tools-runtime.js +61 -0
  314. package/dist/repertoire/tools-session.js +809 -0
  315. package/dist/repertoire/tools-shell.js +120 -0
  316. package/dist/repertoire/tools-stripe.js +180 -0
  317. package/dist/repertoire/tools-surface.js +345 -0
  318. package/dist/repertoire/tools-teams.js +64 -61
  319. package/dist/repertoire/tools-travel.js +125 -0
  320. package/dist/repertoire/tools-trip.js +604 -0
  321. package/dist/repertoire/tools-user-profile.js +144 -0
  322. package/dist/repertoire/tools-vault.js +40 -0
  323. package/dist/repertoire/tools-voice.js +144 -0
  324. package/dist/repertoire/tools.js +154 -98
  325. package/dist/repertoire/travel-api-client.js +360 -0
  326. package/dist/repertoire/user-profile.js +131 -0
  327. package/dist/repertoire/vault-setup.js +246 -0
  328. package/dist/repertoire/vault-unlock.js +594 -0
  329. package/dist/scripts/claude-code-hook.js +41 -0
  330. package/dist/scripts/claude-code-stop-hook.js +47 -0
  331. package/dist/senses/attention-queue.js +116 -0
  332. package/dist/senses/await-turn-message.js +58 -0
  333. package/dist/senses/bluebubbles/active-turns.js +216 -0
  334. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  335. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  336. package/dist/senses/bluebubbles/client.js +685 -0
  337. package/dist/senses/bluebubbles/entry.js +77 -0
  338. package/dist/senses/bluebubbles/inbound-log.js +126 -0
  339. package/dist/senses/bluebubbles/index.js +2548 -0
  340. package/dist/senses/bluebubbles/media.js +389 -0
  341. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +45 -16
  342. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +46 -6
  343. package/dist/senses/bluebubbles/processed-log.js +133 -0
  344. package/dist/senses/bluebubbles/replay.js +137 -0
  345. package/dist/senses/bluebubbles/runtime-state.js +137 -0
  346. package/dist/senses/bluebubbles/session-cleanup.js +72 -0
  347. package/dist/senses/bluebubbles-meta-guard.js +40 -0
  348. package/dist/senses/cli/bracketed-paste.js +82 -0
  349. package/dist/senses/cli/image-paste.js +287 -0
  350. package/dist/senses/cli/image-ref-navigation.js +75 -0
  351. package/dist/senses/cli/ink-app.js +156 -0
  352. package/dist/senses/cli/inline-diff.js +64 -0
  353. package/dist/senses/cli/input-keys.js +174 -0
  354. package/dist/senses/cli/kill-ring.js +86 -0
  355. package/dist/senses/cli/message-list.js +51 -0
  356. package/dist/senses/cli/ouro-tui.js +607 -0
  357. package/dist/senses/cli/spinner-imperative.js +135 -0
  358. package/dist/senses/cli/spinner.js +101 -0
  359. package/dist/senses/cli/status-line.js +60 -0
  360. package/dist/senses/cli/streaming-markdown.js +526 -0
  361. package/dist/senses/cli/tool-display.js +85 -0
  362. package/dist/senses/cli/tool-render.js +85 -0
  363. package/dist/senses/cli/tui-store.js +240 -0
  364. package/dist/senses/cli/virtual-list.js +35 -0
  365. package/dist/senses/cli-entry.js +60 -8
  366. package/dist/senses/cli-layout.js +187 -0
  367. package/dist/senses/cli.js +777 -264
  368. package/dist/senses/commands.js +66 -3
  369. package/dist/senses/continuity.js +94 -0
  370. package/dist/senses/habit-turn-message.js +108 -0
  371. package/dist/senses/inner-dialog-worker.js +209 -16
  372. package/dist/senses/inner-dialog.js +682 -91
  373. package/dist/senses/mail-entry.js +66 -0
  374. package/dist/senses/mail.js +379 -0
  375. package/dist/senses/pipeline.js +751 -0
  376. package/dist/senses/proactive-content-guard.js +51 -0
  377. package/dist/senses/shared-turn.js +392 -0
  378. package/dist/senses/surface-tool.js +70 -0
  379. package/dist/senses/teams-entry.js +60 -8
  380. package/dist/senses/teams.js +925 -195
  381. package/dist/senses/trust-gate.js +207 -2
  382. package/dist/senses/voice/audio-playback.js +237 -0
  383. package/dist/senses/voice/audio-routing.js +119 -0
  384. package/dist/senses/voice/elevenlabs.js +202 -0
  385. package/dist/senses/voice/floor-control.js +431 -0
  386. package/dist/senses/voice/floor-controller.js +115 -0
  387. package/dist/senses/voice/golden-path.js +116 -0
  388. package/dist/senses/voice/index.js +29 -0
  389. package/dist/senses/voice/meeting.js +113 -0
  390. package/dist/senses/voice/outbound.js +190 -0
  391. package/dist/senses/voice/phone.js +33 -0
  392. package/dist/senses/voice/playback.js +139 -0
  393. package/dist/senses/voice/realtime-eval.js +496 -0
  394. package/dist/senses/voice/realtime-trace.js +531 -0
  395. package/dist/senses/voice/transcript.js +70 -0
  396. package/dist/senses/voice/turn.js +191 -0
  397. package/dist/senses/voice/twilio-phone-runtime.js +807 -0
  398. package/dist/senses/voice/twilio-phone.js +5077 -0
  399. package/dist/senses/voice/types.js +2 -0
  400. package/dist/senses/voice/whisper.js +161 -0
  401. package/dist/senses/voice-entry.js +81 -0
  402. package/dist/senses/voice-realtime-eval-command.js +99 -0
  403. package/dist/senses/voice-realtime-eval-entry.js +21 -0
  404. package/dist/senses/voice-twilio-entry.js +87 -0
  405. package/dist/trips/core.js +138 -0
  406. package/dist/trips/store.js +265 -0
  407. package/package.json +52 -7
  408. package/skills/agent-commerce.md +106 -0
  409. package/skills/browser-navigation.md +117 -0
  410. package/skills/commerce-setup-guide.md +116 -0
  411. package/skills/commerce-setup.md +84 -0
  412. package/skills/configure-dev-tools.md +99 -0
  413. package/skills/travel-planning.md +138 -0
  414. package/AdoptionSpecialist.ouro/agent.json +0 -20
  415. package/AdoptionSpecialist.ouro/psyche/SOUL.md +0 -22
  416. package/dist/heart/daemon/specialist-orchestrator.js +0 -160
  417. package/dist/heart/daemon/specialist-prompt.js +0 -40
  418. package/dist/heart/daemon/specialist-session.js +0 -142
  419. package/dist/heart/daemon/specialist-tools.js +0 -128
  420. package/dist/heart/daemon/subagent-installer.js +0 -125
  421. package/dist/inner-worker-entry.js +0 -4
  422. package/dist/mind/associative-recall.js +0 -197
  423. package/dist/senses/bluebubbles-client.js +0 -279
  424. package/dist/senses/bluebubbles-entry.js +0 -11
  425. package/dist/senses/bluebubbles.js +0 -332
  426. package/subagents/README.md +0 -73
  427. package/subagents/work-doer.md +0 -233
  428. package/subagents/work-merger.md +0 -624
  429. package/subagents/work-planner.md +0 -373
  430. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  431. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  432. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  433. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  434. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  435. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  436. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  437. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  438. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  439. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  440. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
@@ -0,0 +1,160 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.parseMailroomEntryArgs = parseMailroomEntryArgs;
37
+ exports.runMailroomEntry = runMailroomEntry;
38
+ const fs = __importStar(require("node:fs"));
39
+ const storage_blob_1 = require("@azure/storage-blob");
40
+ const identity_1 = require("@azure/identity");
41
+ const runtime_1 = require("../nerves/runtime");
42
+ const blob_store_1 = require("./blob-store");
43
+ const file_store_1 = require("./file-store");
44
+ const smtp_ingress_1 = require("./smtp-ingress");
45
+ const KEY_VALUE_ARGS = new Map([
46
+ ["registry", "--registry"],
47
+ ["registry-base64", "--registry-base64"],
48
+ ["store", "--store"],
49
+ ["azure-account-url", "--azure-account-url"],
50
+ ["azure-container", "--azure-container"],
51
+ ["azure-managed-identity-client-id", "--azure-managed-identity-client-id"],
52
+ ["smtp-port", "--smtp-port"],
53
+ ["http-port", "--http-port"],
54
+ ["host", "--host"],
55
+ ]);
56
+ function expandKeyValueArgs(args) {
57
+ const expanded = [];
58
+ for (const arg of args) {
59
+ const equalsIndex = arg.indexOf("=");
60
+ if (!arg.startsWith("--") && equalsIndex > 0) {
61
+ const key = arg.slice(0, equalsIndex).trim();
62
+ const flag = KEY_VALUE_ARGS.get(key);
63
+ if (flag) {
64
+ expanded.push(flag, arg.slice(equalsIndex + 1));
65
+ continue;
66
+ }
67
+ }
68
+ expanded.push(arg);
69
+ }
70
+ return expanded;
71
+ }
72
+ function optionalValue(args, flag) {
73
+ const index = args.indexOf(flag);
74
+ return index === -1 ? undefined : args[index + 1];
75
+ }
76
+ function optionalNumber(args, flag, fallback) {
77
+ const index = args.indexOf(flag);
78
+ if (index === -1)
79
+ return fallback;
80
+ const value = Number.parseInt(args[index + 1] ?? "", 10);
81
+ if (!Number.isInteger(value) || value < 0 || value > 65535) {
82
+ throw new Error(`${flag} must be a TCP port`);
83
+ }
84
+ return value;
85
+ }
86
+ function optionalString(args, flag, fallback) {
87
+ return optionalValue(args, flag) ?? fallback;
88
+ }
89
+ function parseMailroomEntryArgs(args) {
90
+ const expanded = expandKeyValueArgs(args);
91
+ const storePath = optionalValue(expanded, "--store");
92
+ const azureAccountUrl = optionalValue(expanded, "--azure-account-url");
93
+ if (!storePath && !azureAccountUrl) {
94
+ throw new Error("Missing --store or --azure-account-url");
95
+ }
96
+ const registryPath = optionalValue(expanded, "--registry");
97
+ const registryBase64 = optionalValue(expanded, "--registry-base64");
98
+ if (!registryPath && !registryBase64) {
99
+ throw new Error("Missing --registry or --registry-base64");
100
+ }
101
+ const parsed = {
102
+ ...(registryPath ? { registryPath } : {}),
103
+ ...(registryBase64 ? { registryBase64 } : {}),
104
+ ...(storePath ? { storePath } : {}),
105
+ ...(azureAccountUrl ? { azureAccountUrl } : {}),
106
+ azureContainer: optionalString(expanded, "--azure-container", "mailroom"),
107
+ ...(optionalValue(expanded, "--azure-managed-identity-client-id") ? { azureManagedIdentityClientId: optionalValue(expanded, "--azure-managed-identity-client-id") } : {}),
108
+ smtpPort: optionalNumber(expanded, "--smtp-port", 2525),
109
+ httpPort: optionalNumber(expanded, "--http-port", 8080),
110
+ host: optionalString(expanded, "--host", "0.0.0.0"),
111
+ };
112
+ (0, runtime_1.emitNervesEvent)({
113
+ component: "senses",
114
+ event: "senses.mail_entry_args_parsed",
115
+ message: "mailroom entry args parsed",
116
+ meta: { registryPath: parsed.registryPath ?? null, registryBase64: parsed.registryBase64 ? "present" : null, storePath: parsed.storePath ?? null, azureAccountUrl: parsed.azureAccountUrl ?? null, azureContainer: parsed.azureContainer, azureManagedIdentityClientId: parsed.azureManagedIdentityClientId ? "present" : null, smtpPort: parsed.smtpPort, httpPort: parsed.httpPort },
117
+ });
118
+ return parsed;
119
+ }
120
+ function createStore(parsed) {
121
+ if (parsed.azureAccountUrl) {
122
+ const credential = parsed.azureManagedIdentityClientId
123
+ ? new identity_1.DefaultAzureCredential({ managedIdentityClientId: parsed.azureManagedIdentityClientId })
124
+ : new identity_1.DefaultAzureCredential();
125
+ return new blob_store_1.AzureBlobMailroomStore({
126
+ serviceClient: new storage_blob_1.BlobServiceClient(parsed.azureAccountUrl, credential),
127
+ containerName: parsed.azureContainer,
128
+ });
129
+ }
130
+ return new file_store_1.FileMailroomStore({ rootDir: parsed.storePath });
131
+ }
132
+ function readRegistry(parsed) {
133
+ if (parsed.registryBase64) {
134
+ return JSON.parse(Buffer.from(parsed.registryBase64, "base64").toString("utf-8"));
135
+ }
136
+ return JSON.parse(fs.readFileSync(parsed.registryPath, "utf-8"));
137
+ }
138
+ function runMailroomEntry(args = process.argv.slice(2)) {
139
+ const parsed = parseMailroomEntryArgs(args);
140
+ const registry = readRegistry(parsed);
141
+ const servers = (0, smtp_ingress_1.startMailroomIngress)({
142
+ registry,
143
+ store: createStore(parsed),
144
+ smtpPort: parsed.smtpPort,
145
+ httpPort: parsed.httpPort,
146
+ host: parsed.host,
147
+ });
148
+ (0, runtime_1.emitNervesEvent)({
149
+ component: "senses",
150
+ event: "senses.mail_entry_started",
151
+ message: "mailroom entry started",
152
+ meta: { domain: registry.domain, smtpPort: parsed.smtpPort, httpPort: parsed.httpPort },
153
+ });
154
+ return servers;
155
+ }
156
+ /* v8 ignore start -- exercised by packaged/container entrypoint smoke rather than in-process unit tests. @preserve */
157
+ if (require.main === module) {
158
+ runMailroomEntry();
159
+ }
160
+ /* v8 ignore stop */
@@ -0,0 +1,457 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.readPrivateEnvelope = exports.FileMailroomStore = void 0;
37
+ exports.ingestRawMailToStore = ingestRawMailToStore;
38
+ exports.decryptMessages = decryptMessages;
39
+ const fs = __importStar(require("node:fs"));
40
+ const path = __importStar(require("node:path"));
41
+ const runtime_1 = require("../nerves/runtime");
42
+ const core_1 = require("./core");
43
+ Object.defineProperty(exports, "readPrivateEnvelope", { enumerable: true, get: function () { return core_1.readPrivateEnvelope; } });
44
+ const search_cache_1 = require("./search-cache");
45
+ const migration_1 = require("./migration");
46
+ function ensureDir(dir) {
47
+ fs.mkdirSync(dir, { recursive: true });
48
+ }
49
+ function applyOptionalLimit(items, limit) {
50
+ return typeof limit === "number" ? items.slice(0, limit) : items;
51
+ }
52
+ function readJson(filePath) {
53
+ try {
54
+ return JSON.parse(fs.readFileSync(filePath, "utf-8"));
55
+ }
56
+ catch {
57
+ return null;
58
+ }
59
+ }
60
+ function writeJson(filePath, value) {
61
+ ensureDir(path.dirname(filePath));
62
+ fs.writeFileSync(filePath, `${JSON.stringify(value, null, 2)}\n`, "utf-8");
63
+ }
64
+ function compareNewestFirst(left, right) {
65
+ return Date.parse(right.receivedAt) - Date.parse(left.receivedAt);
66
+ }
67
+ function compareCandidatesNewestFirst(left, right) {
68
+ return Date.parse(right.lastSeenAt) - Date.parse(left.lastSeenAt);
69
+ }
70
+ function sourceMatchesFilter(source, filter) {
71
+ if (!filter)
72
+ return true;
73
+ if (!source)
74
+ return false;
75
+ return source.toLowerCase() === filter.toLowerCase();
76
+ }
77
+ class FileMailroomStore {
78
+ rootDir;
79
+ mailSearchCache;
80
+ constructor(options) {
81
+ this.rootDir = options.rootDir;
82
+ this.mailSearchCache = options.mailSearchCache ?? {
83
+ cacheDirForAgent: () => path.resolve(this.rootDir, "..", "mail-search"),
84
+ };
85
+ ensureDir(this.messagesDir);
86
+ ensureDir(this.rawDir);
87
+ ensureDir(this.logsDir);
88
+ ensureDir(this.candidatesDir);
89
+ ensureDir(this.decisionsDir);
90
+ ensureDir(this.outboundDir);
91
+ if (options.migrateAgentId) {
92
+ const searchCacheRoot = this.mailSearchCache.cacheDirForAgent?.(options.migrateAgentId)
93
+ ?? path.resolve(this.rootDir, "..", "mail-search");
94
+ (0, migration_1.migrateLocalMailroomToPlaintext)({
95
+ agentId: options.migrateAgentId,
96
+ mailroomRoot: this.rootDir,
97
+ searchCacheRoot,
98
+ });
99
+ }
100
+ (0, runtime_1.emitNervesEvent)({
101
+ component: "senses",
102
+ event: "senses.mail_file_store_init",
103
+ message: "file mailroom store initialized",
104
+ meta: { rootDir: this.rootDir, migrated: options.migrateAgentId !== undefined },
105
+ });
106
+ }
107
+ get messagesDir() {
108
+ return path.join(this.rootDir, "messages");
109
+ }
110
+ get rawDir() {
111
+ return path.join(this.rootDir, "raw");
112
+ }
113
+ get logsDir() {
114
+ return path.join(this.rootDir, "access-log");
115
+ }
116
+ get candidatesDir() {
117
+ return path.join(this.rootDir, "candidates");
118
+ }
119
+ get decisionsDir() {
120
+ return path.join(this.rootDir, "decisions");
121
+ }
122
+ get outboundDir() {
123
+ return path.join(this.rootDir, "outbound");
124
+ }
125
+ messagePath(id) {
126
+ return path.join(this.messagesDir, `${id}.json`);
127
+ }
128
+ candidatePath(id) {
129
+ return path.join(this.candidatesDir, `${id}.json`);
130
+ }
131
+ rawPath(objectName) {
132
+ return path.join(this.rootDir, objectName);
133
+ }
134
+ decisionLogPath(agentId) {
135
+ return path.join(this.decisionsDir, `${agentId}.jsonl`);
136
+ }
137
+ outboundPath(id) {
138
+ return path.join(this.outboundDir, `${id}.json`);
139
+ }
140
+ accessLogPath(agentId) {
141
+ return path.join(this.logsDir, `${agentId}.jsonl`);
142
+ }
143
+ async putRawMessage(input) {
144
+ const { message, rawMime, privateEnvelope, candidate } = await (0, core_1.buildPlaintextStoredMailMessage)(input);
145
+ const existing = readJson(this.messagePath(message.id));
146
+ if (existing) {
147
+ (0, search_cache_1.upsertMailSearchCacheDocument)(existing, privateEnvelope, this.mailSearchCache);
148
+ (0, runtime_1.emitNervesEvent)({
149
+ component: "senses",
150
+ event: "senses.mail_store_dedupe",
151
+ message: "mailroom store deduped existing message",
152
+ meta: { id: message.id, agentId: message.agentId },
153
+ });
154
+ return { created: false, message: existing };
155
+ }
156
+ ensureDir(path.dirname(this.rawPath(message.rawObject)));
157
+ fs.writeFileSync(this.rawPath(message.rawObject), rawMime);
158
+ writeJson(this.messagePath(message.id), message);
159
+ (0, search_cache_1.upsertMailSearchCacheDocument)(message, privateEnvelope, this.mailSearchCache);
160
+ if (candidate) {
161
+ writeJson(this.candidatePath(candidate.id), candidate);
162
+ }
163
+ (0, runtime_1.emitNervesEvent)({
164
+ component: "senses",
165
+ event: "senses.mail_file_store_plaintext_written",
166
+ message: "mailroom store wrote plaintext message",
167
+ meta: { id: message.id, agentId: message.agentId, candidate: candidate !== undefined },
168
+ });
169
+ return { created: true, message };
170
+ }
171
+ async getMessage(id) {
172
+ const message = readJson(this.messagePath(id));
173
+ (0, runtime_1.emitNervesEvent)({
174
+ component: "senses",
175
+ event: "senses.mail_store_message_read",
176
+ message: "mailroom store read message",
177
+ meta: { id, found: message !== null },
178
+ });
179
+ return message;
180
+ }
181
+ async listMessages(filters) {
182
+ const messages = fs.readdirSync(this.messagesDir)
183
+ .filter((name) => name.endsWith(".json"))
184
+ .map((name) => readJson(path.join(this.messagesDir, name)))
185
+ .filter((message) => message !== null)
186
+ .filter((message) => message.agentId === filters.agentId)
187
+ .filter((message) => filters.placement ? message.placement === filters.placement : true)
188
+ .filter((message) => filters.compartmentKind ? message.compartmentKind === filters.compartmentKind : true)
189
+ .filter((message) => sourceMatchesFilter(message.source, filters.source))
190
+ .sort(compareNewestFirst);
191
+ const limited = applyOptionalLimit(messages, filters.limit);
192
+ (0, runtime_1.emitNervesEvent)({
193
+ component: "senses",
194
+ event: "senses.mail_store_messages_listed",
195
+ message: "mailroom store listed messages",
196
+ meta: { agentId: filters.agentId, count: limited.length },
197
+ });
198
+ return limited;
199
+ }
200
+ async updateMessagePlacement(id, placement) {
201
+ const message = readJson(this.messagePath(id));
202
+ if (!message) {
203
+ (0, runtime_1.emitNervesEvent)({
204
+ component: "senses",
205
+ event: "senses.mail_store_message_placement_updated",
206
+ message: "mailroom store message placement update missed",
207
+ meta: { id, placement, found: false },
208
+ });
209
+ return null;
210
+ }
211
+ const updated = { ...message, placement };
212
+ writeJson(this.messagePath(id), updated);
213
+ (0, search_cache_1.syncMailSearchCacheMetadata)(updated, this.mailSearchCache);
214
+ (0, runtime_1.emitNervesEvent)({
215
+ component: "senses",
216
+ event: "senses.mail_store_message_placement_updated",
217
+ message: "mailroom store updated message placement",
218
+ meta: { id, placement, found: true },
219
+ });
220
+ return updated;
221
+ }
222
+ async readRawMime(message, _privateKeys) {
223
+ const filePath = this.rawPath(message.rawObject);
224
+ let buffer;
225
+ try {
226
+ buffer = fs.readFileSync(filePath);
227
+ }
228
+ catch {
229
+ buffer = null;
230
+ }
231
+ (0, runtime_1.emitNervesEvent)({
232
+ component: "senses",
233
+ event: "senses.mail_store_raw_read",
234
+ message: "mailroom store read raw plaintext mime",
235
+ meta: { id: message.id, found: buffer !== null },
236
+ });
237
+ return buffer;
238
+ }
239
+ async putScreenerCandidate(candidate) {
240
+ writeJson(this.candidatePath(candidate.id), candidate);
241
+ (0, runtime_1.emitNervesEvent)({
242
+ component: "senses",
243
+ event: "senses.mail_screener_candidate_written",
244
+ message: "mail screener candidate written",
245
+ meta: { id: candidate.id, agentId: candidate.agentId, status: candidate.status },
246
+ });
247
+ return candidate;
248
+ }
249
+ async updateScreenerCandidate(candidate) {
250
+ return this.putScreenerCandidate(candidate);
251
+ }
252
+ async listScreenerCandidates(filters) {
253
+ const candidates = fs.readdirSync(this.candidatesDir)
254
+ .filter((name) => name.endsWith(".json"))
255
+ .map((name) => readJson(path.join(this.candidatesDir, name)))
256
+ .filter((candidate) => candidate !== null)
257
+ .filter((candidate) => candidate.agentId === filters.agentId)
258
+ .filter((candidate) => filters.status ? candidate.status === filters.status : true)
259
+ .filter((candidate) => filters.placement ? candidate.placement === filters.placement : true)
260
+ .sort(compareCandidatesNewestFirst)
261
+ .slice(0, filters.limit ?? 50);
262
+ (0, runtime_1.emitNervesEvent)({
263
+ component: "senses",
264
+ event: "senses.mail_screener_candidates_listed",
265
+ message: "mail screener candidates listed",
266
+ meta: { agentId: filters.agentId, count: candidates.length },
267
+ });
268
+ return candidates;
269
+ }
270
+ async recordMailDecision(entry) {
271
+ const complete = {
272
+ schemaVersion: 1,
273
+ ...entry,
274
+ id: entry.id ?? `decision_${Date.now()}_${Math.random().toString(36).slice(2, 8)}`,
275
+ createdAt: entry.createdAt ?? new Date().toISOString(),
276
+ };
277
+ ensureDir(this.decisionsDir);
278
+ fs.appendFileSync(this.decisionLogPath(entry.agentId), `${JSON.stringify(complete)}\n`, "utf-8");
279
+ (0, runtime_1.emitNervesEvent)({
280
+ component: "senses",
281
+ event: "senses.mail_decision_recorded",
282
+ message: "mail decision recorded",
283
+ meta: { agentId: entry.agentId, messageId: entry.messageId, action: entry.action },
284
+ });
285
+ return complete;
286
+ }
287
+ async listMailDecisions(agentId) {
288
+ const filePath = this.decisionLogPath(agentId);
289
+ if (!fs.existsSync(filePath)) {
290
+ (0, runtime_1.emitNervesEvent)({
291
+ component: "senses",
292
+ event: "senses.mail_decisions_listed",
293
+ message: "mail decisions listed",
294
+ meta: { agentId, count: 0 },
295
+ });
296
+ return [];
297
+ }
298
+ const entries = fs.readFileSync(filePath, "utf-8")
299
+ .split(/\r?\n/)
300
+ .filter(Boolean)
301
+ .map((line) => JSON.parse(line));
302
+ (0, runtime_1.emitNervesEvent)({
303
+ component: "senses",
304
+ event: "senses.mail_decisions_listed",
305
+ message: "mail decisions listed",
306
+ meta: { agentId, count: entries.length },
307
+ });
308
+ return entries;
309
+ }
310
+ async upsertMailOutbound(record) {
311
+ writeJson(this.outboundPath(record.id), record);
312
+ (0, runtime_1.emitNervesEvent)({
313
+ component: "senses",
314
+ event: "senses.mail_outbound_record_written",
315
+ message: "mail outbound record written",
316
+ meta: { agentId: record.agentId, id: record.id, status: record.status },
317
+ });
318
+ return record;
319
+ }
320
+ async getMailOutbound(id) {
321
+ const record = readJson(this.outboundPath(id));
322
+ (0, runtime_1.emitNervesEvent)({
323
+ component: "senses",
324
+ event: "senses.mail_outbound_record_read",
325
+ message: "mail outbound record read",
326
+ meta: { id, found: record !== null },
327
+ });
328
+ return record;
329
+ }
330
+ async listMailOutbound(agentId) {
331
+ const records = fs.readdirSync(this.outboundDir)
332
+ .filter((name) => name.endsWith(".json"))
333
+ .map((name) => readJson(path.join(this.outboundDir, name)))
334
+ .filter((record) => record !== null)
335
+ .filter((record) => record.agentId === agentId)
336
+ .sort((left, right) => right.updatedAt.localeCompare(left.updatedAt));
337
+ (0, runtime_1.emitNervesEvent)({
338
+ component: "senses",
339
+ event: "senses.mail_outbound_records_listed",
340
+ message: "mail outbound records listed",
341
+ meta: { agentId, count: records.length },
342
+ });
343
+ return records;
344
+ }
345
+ async recordAccess(entry) {
346
+ const complete = {
347
+ ...entry,
348
+ id: `access_${Date.now()}_${Math.random().toString(36).slice(2, 8)}`,
349
+ accessedAt: new Date().toISOString(),
350
+ };
351
+ ensureDir(this.logsDir);
352
+ fs.appendFileSync(this.accessLogPath(entry.agentId), `${JSON.stringify(complete)}\n`, "utf-8");
353
+ (0, runtime_1.emitNervesEvent)({
354
+ component: "senses",
355
+ event: "senses.mail_access_recorded",
356
+ message: "mail access recorded",
357
+ meta: { agentId: entry.agentId, messageId: entry.messageId ?? null, tool: entry.tool },
358
+ });
359
+ return complete;
360
+ }
361
+ async listAccessLog(agentId) {
362
+ const filePath = this.accessLogPath(agentId);
363
+ if (!fs.existsSync(filePath)) {
364
+ (0, runtime_1.emitNervesEvent)({
365
+ component: "senses",
366
+ event: "senses.mail_access_log_listed",
367
+ message: "mail access log listed",
368
+ meta: { agentId, count: 0 },
369
+ });
370
+ return [];
371
+ }
372
+ const lines = fs.readFileSync(filePath, "utf-8")
373
+ .split(/\r?\n/)
374
+ .filter(Boolean);
375
+ const entries = [];
376
+ let malformedEntriesSkipped = 0;
377
+ for (const line of lines) {
378
+ try {
379
+ entries.push(JSON.parse(line));
380
+ }
381
+ catch {
382
+ malformedEntriesSkipped += 1;
383
+ }
384
+ }
385
+ if (malformedEntriesSkipped > 0) {
386
+ entries.malformedEntriesSkipped = malformedEntriesSkipped;
387
+ (0, runtime_1.emitNervesEvent)({
388
+ level: "warn",
389
+ component: "senses",
390
+ event: "senses.mail_access_log_malformed_lines_skipped",
391
+ message: "skipped malformed file-backed mail access log lines",
392
+ meta: { agentId, malformedEntriesSkipped },
393
+ });
394
+ }
395
+ (0, runtime_1.emitNervesEvent)({
396
+ component: "senses",
397
+ event: "senses.mail_access_log_listed",
398
+ message: "mail access log listed",
399
+ meta: { agentId, count: entries.length, malformedEntriesSkipped },
400
+ });
401
+ return entries;
402
+ }
403
+ }
404
+ exports.FileMailroomStore = FileMailroomStore;
405
+ async function ingestRawMailToStore(input) {
406
+ const { resolveMailAddress } = await Promise.resolve().then(() => __importStar(require("./core")));
407
+ const { classifyResolvedMailPlacement } = await Promise.resolve().then(() => __importStar(require("./policy")));
408
+ const accepted = [];
409
+ const rejectedRecipients = [];
410
+ for (const recipient of input.envelope.rcptTo) {
411
+ const resolved = resolveMailAddress(input.registry, recipient);
412
+ if (!resolved) {
413
+ rejectedRecipients.push(recipient);
414
+ continue;
415
+ }
416
+ const classification = classifyResolvedMailPlacement({
417
+ registry: input.registry,
418
+ resolved,
419
+ sender: input.envelope.mailFrom,
420
+ ...(input.authentication ? { authentication: input.authentication } : {}),
421
+ });
422
+ const result = await input.store.putRawMessage({
423
+ resolved,
424
+ envelope: input.envelope,
425
+ rawMime: input.rawMime,
426
+ receivedAt: input.receivedAt,
427
+ ...(input.ingest ? { ingest: input.ingest } : {}),
428
+ classification,
429
+ });
430
+ accepted.push(result.message);
431
+ }
432
+ (0, runtime_1.emitNervesEvent)({
433
+ component: "senses",
434
+ event: "senses.mail_ingest_complete",
435
+ message: "mail ingest completed",
436
+ meta: { accepted: accepted.length, rejected: rejectedRecipients.length },
437
+ });
438
+ return { accepted, rejectedRecipients };
439
+ }
440
+ /**
441
+ * Reader-side convenience: produce a `DecryptedMailMessage[]` from any mix of
442
+ * stored variants. Plaintext-form messages pass through without touching
443
+ * `privateKeys`; encrypted-form messages decrypt with the matching key.
444
+ * Throws `MissingPrivateMailKeyError` on the first encrypted message whose key
445
+ * is absent — callers that want per-message resilience should call
446
+ * `readPrivateEnvelope` in their own loop.
447
+ */
448
+ function decryptMessages(messages, privateKeys) {
449
+ const decrypted = messages.map((message) => (0, core_1.readDecryptedMailMessage)(message, privateKeys));
450
+ (0, runtime_1.emitNervesEvent)({
451
+ component: "senses",
452
+ event: "senses.mail_messages_decrypted",
453
+ message: "mail messages projected to decrypted view",
454
+ meta: { count: decrypted.length },
455
+ });
456
+ return decrypted;
457
+ }