@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,131 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.deliverCrossChatMessage = deliverCrossChatMessage;
4
+ const types_1 = require("../mind/friends/types");
5
+ const runtime_1 = require("../nerves/runtime");
6
+ function buildPendingEnvelope(request, agentName, now) {
7
+ return {
8
+ from: agentName,
9
+ friendId: request.friendId,
10
+ channel: request.channel,
11
+ key: request.key,
12
+ content: request.content,
13
+ timestamp: now,
14
+ };
15
+ }
16
+ function queueForLater(request, deps, detail) {
17
+ deps.queuePending(buildPendingEnvelope(request, deps.agentName, (deps.now ?? Date.now)()));
18
+ return {
19
+ status: "queued_for_later",
20
+ detail,
21
+ };
22
+ }
23
+ function isExplicitlyAuthorized(request) {
24
+ return request.intent === "explicit_cross_chat"
25
+ && Boolean(request.authorizingSession)
26
+ && (0, types_1.isTrustedLevel)(request.authorizingSession?.trustLevel);
27
+ }
28
+ async function deliverCrossChatMessage(request, deps) {
29
+ (0, runtime_1.emitNervesEvent)({
30
+ component: "engine",
31
+ event: "engine.cross_chat_delivery_start",
32
+ message: "resolving cross-chat delivery",
33
+ meta: {
34
+ friendId: request.friendId,
35
+ channel: request.channel,
36
+ key: request.key,
37
+ intent: request.intent,
38
+ authorizingTrustLevel: request.authorizingSession?.trustLevel ?? null,
39
+ },
40
+ });
41
+ if (!isExplicitlyAuthorized(request) && request.intent !== "generic_outreach") {
42
+ const result = {
43
+ status: "blocked",
44
+ detail: "cross-chat delivery requires a trusted asking session or generic outreach intent",
45
+ };
46
+ (0, runtime_1.emitNervesEvent)({
47
+ level: "warn",
48
+ component: "engine",
49
+ event: "engine.cross_chat_delivery_end",
50
+ message: "blocked cross-chat delivery",
51
+ meta: {
52
+ friendId: request.friendId,
53
+ channel: request.channel,
54
+ key: request.key,
55
+ status: result.status,
56
+ },
57
+ });
58
+ return result;
59
+ }
60
+ const deliverer = deps.deliverers?.[request.channel];
61
+ if (!deliverer) {
62
+ const result = queueForLater(request, deps, "live delivery unavailable right now; queued for the next active turn");
63
+ (0, runtime_1.emitNervesEvent)({
64
+ component: "engine",
65
+ event: "engine.cross_chat_delivery_end",
66
+ message: "queued explicit cross-chat delivery because no live deliverer was available",
67
+ meta: {
68
+ friendId: request.friendId,
69
+ channel: request.channel,
70
+ key: request.key,
71
+ status: result.status,
72
+ },
73
+ });
74
+ return result;
75
+ }
76
+ try {
77
+ const direct = await deliverer(request);
78
+ if (direct.status === "delivered_now" || direct.status === "blocked" || direct.status === "failed") {
79
+ const result = {
80
+ status: direct.status,
81
+ detail: direct.detail,
82
+ };
83
+ (0, runtime_1.emitNervesEvent)({
84
+ level: result.status === "failed" ? "error" : result.status === "blocked" ? "warn" : "info",
85
+ component: "engine",
86
+ event: "engine.cross_chat_delivery_end",
87
+ message: "completed direct cross-chat delivery resolution",
88
+ meta: {
89
+ friendId: request.friendId,
90
+ channel: request.channel,
91
+ key: request.key,
92
+ status: result.status,
93
+ },
94
+ });
95
+ return result;
96
+ }
97
+ const result = queueForLater(request, deps, direct.detail.trim() || "live delivery unavailable right now; queued for the next active turn");
98
+ (0, runtime_1.emitNervesEvent)({
99
+ component: "engine",
100
+ event: "engine.cross_chat_delivery_end",
101
+ message: "queued explicit cross-chat delivery after adapter reported unavailability",
102
+ meta: {
103
+ friendId: request.friendId,
104
+ channel: request.channel,
105
+ key: request.key,
106
+ status: result.status,
107
+ },
108
+ });
109
+ return result;
110
+ }
111
+ catch (error) {
112
+ const result = {
113
+ status: "failed",
114
+ detail: error instanceof Error ? error.message : String(error),
115
+ };
116
+ (0, runtime_1.emitNervesEvent)({
117
+ level: "error",
118
+ component: "engine",
119
+ event: "engine.cross_chat_delivery_end",
120
+ message: "cross-chat delivery threw unexpectedly",
121
+ meta: {
122
+ friendId: request.friendId,
123
+ channel: request.channel,
124
+ key: request.key,
125
+ status: result.status,
126
+ reason: result.detail,
127
+ },
128
+ });
129
+ return result;
130
+ }
131
+ }
@@ -0,0 +1,419 @@
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.vaultUnlockOrRecoverFix = vaultUnlockOrRecoverFix;
37
+ exports.checkAgentConfig = checkAgentConfig;
38
+ exports.checkAgentConfigWithProviderHealth = checkAgentConfigWithProviderHealth;
39
+ const fs = __importStar(require("fs"));
40
+ const path = __importStar(require("path"));
41
+ const identity_1 = require("../identity");
42
+ const runtime_1 = require("../../nerves/runtime");
43
+ const provider_models_1 = require("../provider-models");
44
+ const provider_credentials_1 = require("../provider-credentials");
45
+ const provider_readiness_cache_1 = require("../provider-readiness-cache");
46
+ const vault_unlock_1 = require("../../repertoire/vault-unlock");
47
+ const readiness_repair_1 = require("./readiness-repair");
48
+ const provider_ping_progress_1 = require("./provider-ping-progress");
49
+ const LANES = [
50
+ { lane: "outward", facing: "humanFacing" },
51
+ { lane: "inner", facing: "agentFacing" },
52
+ ];
53
+ function isAgentProvider(value) {
54
+ return Object.prototype.hasOwnProperty.call(identity_1.PROVIDER_CREDENTIALS, value);
55
+ }
56
+ function agentRootFor(agentName, bundlesRoot) {
57
+ return path.join(bundlesRoot, `${agentName}.ouro`);
58
+ }
59
+ function configPathFor(agentName, bundlesRoot) {
60
+ return path.join(agentRootFor(agentName, bundlesRoot), "agent.json");
61
+ }
62
+ function laneForFacing(facing) {
63
+ return facing === "humanFacing" ? "outward" : "inner";
64
+ }
65
+ function resolveFacingProvider(parsed, facing, agentName, agentJsonPath) {
66
+ const raw = parsed[facing];
67
+ if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
68
+ return {
69
+ ok: false,
70
+ result: {
71
+ ok: false,
72
+ error: `agent.json for '${agentName}' is missing ${facing}.provider`,
73
+ fix: `Add ${facing}: { provider, model } to ${agentJsonPath}. Valid providers: ${Object.keys(identity_1.PROVIDER_CREDENTIALS).join(", ")}`,
74
+ },
75
+ };
76
+ }
77
+ const provider = raw.provider;
78
+ if (typeof provider !== "string" || provider.length === 0) {
79
+ return {
80
+ ok: false,
81
+ result: {
82
+ ok: false,
83
+ error: `agent.json for '${agentName}' is missing ${facing}.provider`,
84
+ fix: `Set ${facing}.provider in ${agentJsonPath}. Valid providers: ${Object.keys(identity_1.PROVIDER_CREDENTIALS).join(", ")}`,
85
+ },
86
+ };
87
+ }
88
+ if (!isAgentProvider(provider)) {
89
+ return {
90
+ ok: false,
91
+ result: {
92
+ ok: false,
93
+ error: `Unknown provider '${provider}' in ${facing}.provider for '${agentName}'`,
94
+ fix: `Set ${facing}.provider to one of: ${Object.keys(identity_1.PROVIDER_CREDENTIALS).join(", ")}`,
95
+ },
96
+ };
97
+ }
98
+ const rawModel = raw.model;
99
+ const model = typeof rawModel === "string" && rawModel.trim().length > 0
100
+ ? rawModel.trim()
101
+ : (0, provider_models_1.getDefaultModelForProvider)(provider);
102
+ return { ok: true, selected: { facing, lane: laneForFacing(facing), provider, model } };
103
+ }
104
+ function readAgentConfigForProviderCheck(agentName, bundlesRoot) {
105
+ const agentJsonPath = configPathFor(agentName, bundlesRoot);
106
+ let raw;
107
+ try {
108
+ raw = fs.readFileSync(agentJsonPath, "utf-8");
109
+ }
110
+ catch {
111
+ return {
112
+ ok: false,
113
+ result: {
114
+ ok: false,
115
+ error: `agent.json not found at ${agentJsonPath}`,
116
+ fix: `Run 'ouro hatch ${agentName}' to create the agent bundle, or verify that ${bundlesRoot}/${agentName}.ouro/ exists.`,
117
+ },
118
+ };
119
+ }
120
+ let parsed;
121
+ try {
122
+ parsed = JSON.parse(raw);
123
+ }
124
+ catch {
125
+ return {
126
+ ok: false,
127
+ result: {
128
+ ok: false,
129
+ error: `agent.json at ${agentJsonPath} contains invalid JSON`,
130
+ fix: `Open ${agentJsonPath} and fix the JSON syntax.`,
131
+ },
132
+ };
133
+ }
134
+ if (parsed.enabled === false) {
135
+ return { ok: true, disabled: true, agentJsonPath, parsed };
136
+ }
137
+ return { ok: true, disabled: false, agentJsonPath, parsed };
138
+ }
139
+ function readProviderSelectionForCheck(agentName, bundlesRoot) {
140
+ const configResult = readAgentConfigForProviderCheck(agentName, bundlesRoot);
141
+ if (!configResult.ok)
142
+ return { ok: false, result: configResult.result };
143
+ if (configResult.disabled)
144
+ return { ok: true, disabled: true };
145
+ const bindings = {};
146
+ for (const { lane, facing } of LANES) {
147
+ const selected = resolveFacingProvider(configResult.parsed, facing, agentName, configResult.agentJsonPath);
148
+ if (!selected.ok)
149
+ return { ok: false, result: selected.result };
150
+ bindings[lane] = selected.selected;
151
+ }
152
+ return {
153
+ ok: true,
154
+ disabled: false,
155
+ agentRoot: agentRootFor(agentName, bundlesRoot),
156
+ bindings,
157
+ };
158
+ }
159
+ function providerCredentialConfig(record) {
160
+ return {
161
+ ...record.credentials,
162
+ ...record.config,
163
+ };
164
+ }
165
+ function pingAttemptCount(result) {
166
+ if (Array.isArray(result.attempts))
167
+ return result.attempts.length;
168
+ return undefined;
169
+ }
170
+ function missingCredentialResult(agentName, lane, provider, model, credentialPath) {
171
+ return {
172
+ ok: false,
173
+ error: `${lane} provider ${provider} model ${model} has no credentials in ${agentName}'s vault at ${credentialPath}`,
174
+ fix: `Run 'ouro auth --agent ${agentName} --provider ${provider}' to authenticate.`,
175
+ issue: (0, readiness_repair_1.providerCredentialMissingIssue)({
176
+ agentName,
177
+ lane,
178
+ provider,
179
+ model,
180
+ credentialPath,
181
+ }),
182
+ };
183
+ }
184
+ function isTransientVaultError(error) {
185
+ const normalized = error.toLowerCase();
186
+ return (normalized.includes("timed out") ||
187
+ normalized.includes("econnrefused") ||
188
+ normalized.includes("socket hang up") ||
189
+ normalized.includes("etimedout"));
190
+ }
191
+ function invalidPoolResult(agentName, lane, provider, model, pool) {
192
+ if (pool.reason === "unavailable" && isTransientVaultError(pool.error)) {
193
+ return {
194
+ ok: false,
195
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials from ${agentName}'s vault: ${pool.error}`,
196
+ fix: `Vault read timed out -- this usually resolves on retry. Run 'ouro up' again.`,
197
+ };
198
+ }
199
+ if (pool.reason === "unavailable" && isVaultLockedError(pool.error)) {
200
+ return {
201
+ ok: false,
202
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials because ${agentName}'s credential vault is locked on this machine.`,
203
+ fix: vaultUnlockOrRecoverFix(agentName),
204
+ issue: (0, readiness_repair_1.vaultLockedIssue)(agentName),
205
+ };
206
+ }
207
+ if (pool.reason === "unavailable" && (0, vault_unlock_1.isCredentialVaultNotConfiguredError)(pool.error)) {
208
+ return {
209
+ ok: false,
210
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials because ${agentName}'s credential vault is not configured in agent.json.`,
211
+ fix: (0, vault_unlock_1.vaultCreateRecoverFix)(agentName, `Then run 'ouro auth --agent ${agentName} --provider ${provider}' and rerun 'ouro up'.`),
212
+ issue: (0, readiness_repair_1.vaultUnconfiguredIssue)(agentName),
213
+ };
214
+ }
215
+ if (pool.reason === "invalid") {
216
+ return {
217
+ ok: false,
218
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials from ${agentName}'s vault at ${pool.poolPath}: ${pool.error}`,
219
+ fix: `Run 'ouro auth --agent ${agentName} --provider ${provider}' to rewrite this provider credential, then run 'ouro up' again.`,
220
+ };
221
+ }
222
+ return {
223
+ ok: false,
224
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials from ${agentName}'s vault at ${pool.poolPath}: ${pool.error}`,
225
+ fix: vaultUnlockOrRecoverFix(agentName, `Then run 'ouro up' again. If the credential is missing or stale after unlock or recovery, run 'ouro auth --agent ${agentName} --provider ${provider}'.`),
226
+ };
227
+ }
228
+ function isVaultLockedError(error) {
229
+ const normalized = error.toLowerCase();
230
+ return /(?:ouro )?credential vault is locked|vault(?: is)? locked/.test(normalized);
231
+ }
232
+ function vaultUnlockOrRecoverFix(agentName, nextStep = "Then run 'ouro up' again.") {
233
+ return (0, vault_unlock_1.vaultUnlockReplaceRecoverFix)(agentName, nextStep);
234
+ }
235
+ function failedPingResult(agentName, lane, provider, model, result) {
236
+ return {
237
+ ok: false,
238
+ error: `${lane} provider ${provider} model ${model} failed live check: ${result.message}`,
239
+ fix: (0, readiness_repair_1.providerLiveCheckFix)({
240
+ agentName,
241
+ lane,
242
+ provider,
243
+ classification: result.classification,
244
+ }),
245
+ issue: (0, readiness_repair_1.providerLiveCheckFailedIssue)({
246
+ agentName,
247
+ lane,
248
+ provider,
249
+ model,
250
+ classification: result.classification,
251
+ message: result.message,
252
+ }),
253
+ };
254
+ }
255
+ function credentialRecordForLane(pool, provider) {
256
+ return pool.providers[provider];
257
+ }
258
+ function laneAudienceLabel(lane) {
259
+ return lane === "outward" ? "chat" : "inner dialog";
260
+ }
261
+ function bindingLabel(binding) {
262
+ return `${binding.provider} / ${binding.model}`;
263
+ }
264
+ function selectedProviderPlan(agentName, bindings) {
265
+ return [
266
+ `${agentName}: checking the providers in agent.json`,
267
+ ...LANES.map(({ lane }) => `- ${laneAudienceLabel(lane)}: ${bindingLabel(bindings[lane])}`),
268
+ ].join("\n");
269
+ }
270
+ function selectedProvidersForBindings(bindings) {
271
+ return [...new Set(LANES.map(({ lane }) => bindings[lane].provider))];
272
+ }
273
+ function mapVaultRefreshProgress(agentName, onProgress) {
274
+ return (message) => {
275
+ if (message.startsWith("reading vault items for ")) {
276
+ onProgress(`${agentName}: opening saved provider credentials in the vault`);
277
+ return;
278
+ }
279
+ const providerRead = message.match(/^reading ([a-z0-9-]+) credentials\.\.\.$/i);
280
+ if (providerRead) {
281
+ onProgress(`${agentName}: reading saved ${providerRead[1]} credentials`);
282
+ return;
283
+ }
284
+ if (message === "parsing provider credentials...") {
285
+ onProgress(`${agentName}: organizing saved provider credentials`);
286
+ }
287
+ };
288
+ }
289
+ function providerPingSubject(agentName, lanes) {
290
+ const laneList = lanes.map((lane) => laneAudienceLabel(lane)).join(" + ");
291
+ return `${agentName} (${laneList})`;
292
+ }
293
+ /**
294
+ * Structural validation only. Live provider credential validation belongs to
295
+ * checkAgentConfigWithProviderHealth(), which reads the agent vault and pings.
296
+ */
297
+ function checkAgentConfig(agentName, bundlesRoot) {
298
+ const selectionResult = readProviderSelectionForCheck(agentName, bundlesRoot);
299
+ if (!selectionResult.ok)
300
+ return selectionResult.result;
301
+ if (selectionResult.disabled)
302
+ return { ok: true };
303
+ (0, runtime_1.emitNervesEvent)({
304
+ component: "daemon",
305
+ event: "daemon.agent_config_valid",
306
+ message: "agent config validation passed",
307
+ meta: {
308
+ agent: agentName,
309
+ providers: selectedProvidersForBindings(selectionResult.bindings),
310
+ liveProviderCheck: false,
311
+ },
312
+ });
313
+ return { ok: true };
314
+ }
315
+ async function checkAgentConfigWithProviderHealth(agentName, bundlesRoot, deps = {}) {
316
+ const selectionResult = readProviderSelectionForCheck(agentName, bundlesRoot);
317
+ if (!selectionResult.ok)
318
+ return selectionResult.result;
319
+ if (selectionResult.disabled)
320
+ return { ok: true };
321
+ deps.onProgress?.(selectedProviderPlan(agentName, selectionResult.bindings));
322
+ const ping = deps.pingProvider ?? (await Promise.resolve().then(() => __importStar(require("../provider-ping")))).pingProvider;
323
+ const providers = selectedProvidersForBindings(selectionResult.bindings);
324
+ const poolResult = await (0, provider_credentials_1.refreshProviderCredentialPool)(agentName, {
325
+ ...(deps.onProgress ? { onProgress: mapVaultRefreshProgress(agentName, deps.onProgress) } : {}),
326
+ providers,
327
+ preserveCachedOnFailure: true,
328
+ });
329
+ const pingGroups = new Map();
330
+ for (const { lane } of LANES) {
331
+ const binding = selectionResult.bindings[lane];
332
+ if (!poolResult.ok) {
333
+ if (poolResult.reason === "missing") {
334
+ return missingCredentialResult(agentName, lane, binding.provider, binding.model, poolResult.poolPath);
335
+ }
336
+ return invalidPoolResult(agentName, lane, binding.provider, binding.model, {
337
+ ...poolResult,
338
+ reason: poolResult.reason,
339
+ });
340
+ }
341
+ const record = credentialRecordForLane(poolResult.pool, binding.provider);
342
+ if (!record) {
343
+ return missingCredentialResult(agentName, lane, binding.provider, binding.model, poolResult.poolPath);
344
+ }
345
+ const key = `${binding.provider}\0${binding.model}\0${record.revision}`;
346
+ const group = pingGroups.get(key);
347
+ if (group) {
348
+ group.lanes.push(lane);
349
+ }
350
+ else {
351
+ pingGroups.set(key, {
352
+ provider: binding.provider,
353
+ model: binding.model,
354
+ record,
355
+ lanes: [lane],
356
+ });
357
+ }
358
+ }
359
+ const groups = [...pingGroups.values()];
360
+ const pingResults = await Promise.all(groups.map(async (group) => {
361
+ const result = await ping(group.provider, providerCredentialConfig(group.record), {
362
+ model: group.model,
363
+ ...(deps.providerPingOptions ?? {}),
364
+ ...(deps.onProgress
365
+ ? (0, provider_ping_progress_1.createProviderPingProgressReporter)({
366
+ provider: group.provider,
367
+ model: group.model,
368
+ subject: providerPingSubject(agentName, group.lanes),
369
+ }, deps.onProgress)
370
+ : {}),
371
+ });
372
+ return { group, result };
373
+ }));
374
+ let firstFailure = null;
375
+ for (const { group, result } of pingResults) {
376
+ if (!result.ok) {
377
+ for (const lane of group.lanes) {
378
+ (0, provider_readiness_cache_1.recordProviderLaneReadiness)({
379
+ agentName,
380
+ lane,
381
+ provider: group.provider,
382
+ model: group.model,
383
+ credentialRevision: group.record.revision,
384
+ status: "failed",
385
+ checkedAt: new Date().toISOString(),
386
+ error: result.message,
387
+ attempts: pingAttemptCount(result),
388
+ });
389
+ }
390
+ firstFailure ??= failedPingResult(agentName, group.lanes[0], group.provider, group.model, result);
391
+ continue;
392
+ }
393
+ for (const lane of group.lanes) {
394
+ (0, provider_readiness_cache_1.recordProviderLaneReadiness)({
395
+ agentName,
396
+ lane,
397
+ provider: group.provider,
398
+ model: group.model,
399
+ credentialRevision: group.record.revision,
400
+ status: "ready",
401
+ checkedAt: new Date().toISOString(),
402
+ attempts: pingAttemptCount(result),
403
+ });
404
+ }
405
+ }
406
+ if (firstFailure)
407
+ return firstFailure;
408
+ (0, runtime_1.emitNervesEvent)({
409
+ component: "daemon",
410
+ event: "daemon.agent_config_valid",
411
+ message: "agent config validation passed",
412
+ meta: {
413
+ agent: agentName,
414
+ providers: [...new Set([...pingGroups.values()].map((group) => group.provider))],
415
+ liveProviderCheck: true,
416
+ },
417
+ });
418
+ return { ok: true };
419
+ }