@ouro.bot/cli 0.1.0-alpha.50 → 0.1.0-alpha.501

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 (369) hide show
  1. package/README.md +133 -19
  2. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +3 -2
  3. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
  4. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  5. package/changelog.json +3184 -0
  6. package/dist/arc/attention-types.js +8 -0
  7. package/dist/arc/cares.js +140 -0
  8. package/dist/arc/episodes.js +117 -0
  9. package/dist/arc/intentions.js +133 -0
  10. package/dist/arc/json-store.js +117 -0
  11. package/dist/arc/obligations.js +237 -0
  12. package/dist/arc/packets.js +193 -0
  13. package/dist/arc/presence.js +185 -0
  14. package/dist/arc/task-lifecycle.js +65 -0
  15. package/dist/heart/active-work.js +867 -35
  16. package/dist/heart/agent-entry.js +58 -3
  17. package/dist/heart/attachments/image-normalize.js +194 -0
  18. package/dist/heart/attachments/materialize.js +97 -0
  19. package/dist/heart/attachments/originals.js +88 -0
  20. package/dist/heart/attachments/render.js +29 -0
  21. package/dist/heart/attachments/sources/adapter.js +2 -0
  22. package/dist/heart/attachments/sources/bluebubbles.js +156 -0
  23. package/dist/heart/attachments/sources/cli-local-file.js +78 -0
  24. package/dist/heart/attachments/sources/index.js +16 -0
  25. package/dist/heart/attachments/store.js +103 -0
  26. package/dist/heart/attachments/types.js +93 -0
  27. package/dist/heart/auth/auth-flow.js +426 -0
  28. package/dist/heart/background-operations.js +281 -0
  29. package/dist/heart/bundle-state.js +168 -0
  30. package/dist/heart/commitments.js +111 -0
  31. package/dist/heart/config-registry.js +304 -0
  32. package/dist/heart/config.js +119 -129
  33. package/dist/heart/core.js +898 -244
  34. package/dist/heart/cross-chat-delivery.js +131 -0
  35. package/dist/heart/daemon/agent-config-check.js +490 -0
  36. package/dist/heart/daemon/agent-discovery.js +79 -3
  37. package/dist/heart/daemon/agent-service.js +360 -0
  38. package/dist/heart/daemon/agentic-repair.js +216 -0
  39. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  40. package/dist/heart/daemon/cadence.js +70 -0
  41. package/dist/heart/daemon/cli-defaults.js +640 -0
  42. package/dist/heart/daemon/cli-exec.js +7239 -0
  43. package/dist/heart/daemon/cli-help.js +493 -0
  44. package/dist/heart/daemon/cli-parse.js +1533 -0
  45. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  46. package/dist/heart/daemon/cli-render.js +561 -0
  47. package/dist/heart/daemon/cli-types.js +8 -0
  48. package/dist/heart/daemon/connect-bay.js +323 -0
  49. package/dist/heart/daemon/daemon-cli.js +29 -1631
  50. package/dist/heart/daemon/daemon-entry.js +345 -3
  51. package/dist/heart/daemon/daemon-health.js +141 -0
  52. package/dist/heart/daemon/daemon-runtime-sync.js +190 -12
  53. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  54. package/dist/heart/daemon/daemon.js +677 -58
  55. package/dist/heart/daemon/dns-workflow.js +394 -0
  56. package/dist/heart/daemon/doctor-types.js +8 -0
  57. package/dist/heart/daemon/doctor.js +615 -0
  58. package/dist/heart/daemon/health-monitor.js +92 -1
  59. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  60. package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
  61. package/dist/heart/daemon/http-health-probe.js +80 -0
  62. package/dist/heart/daemon/human-command-screens.js +234 -0
  63. package/dist/heart/daemon/human-readiness.js +114 -0
  64. package/dist/heart/daemon/inner-status.js +89 -0
  65. package/dist/heart/daemon/interactive-repair.js +394 -0
  66. package/dist/heart/daemon/launchd.js +25 -5
  67. package/dist/heart/daemon/log-tailer.js +82 -12
  68. package/dist/heart/daemon/logs-prune.js +110 -0
  69. package/dist/heart/daemon/message-router.js +2 -2
  70. package/dist/heart/daemon/os-cron-deps.js +134 -0
  71. package/dist/heart/daemon/ouro-bot-entry.js +4 -2
  72. package/dist/heart/daemon/ouro-entry.js +3 -1
  73. package/dist/heart/daemon/process-manager.js +214 -0
  74. package/dist/heart/daemon/provider-discovery.js +137 -0
  75. package/dist/heart/daemon/provider-ping-progress.js +83 -0
  76. package/dist/heart/daemon/pulse.js +475 -0
  77. package/dist/heart/daemon/readiness-repair.js +365 -0
  78. package/dist/heart/daemon/run-hooks.js +2 -0
  79. package/dist/heart/daemon/runtime-logging.js +67 -16
  80. package/dist/heart/daemon/runtime-metadata.js +73 -0
  81. package/dist/heart/daemon/runtime-mode.js +67 -0
  82. package/dist/heart/daemon/safe-mode.js +161 -0
  83. package/dist/heart/daemon/sense-manager.js +178 -37
  84. package/dist/heart/daemon/session-id-resolver.js +131 -0
  85. package/dist/heart/daemon/skill-management-installer.js +94 -0
  86. package/dist/heart/daemon/socket-client.js +109 -4
  87. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  88. package/dist/heart/daemon/startup-tui.js +264 -0
  89. package/dist/heart/daemon/task-scheduler.js +3 -25
  90. package/dist/heart/daemon/terminal-ui.js +499 -0
  91. package/dist/heart/daemon/thoughts.js +162 -17
  92. package/dist/heart/daemon/up-progress.js +366 -0
  93. package/dist/heart/daemon/vault-items.js +56 -0
  94. package/dist/heart/delegation.js +1 -1
  95. package/dist/heart/habits/habit-migration.js +189 -0
  96. package/dist/heart/habits/habit-parser.js +140 -0
  97. package/dist/heart/habits/habit-runtime-state.js +100 -0
  98. package/dist/heart/habits/habit-scheduler.js +372 -0
  99. package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
  100. package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
  101. package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
  102. package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
  103. package/dist/heart/identity.js +201 -66
  104. package/dist/heart/kept-notes.js +357 -0
  105. package/dist/heart/kicks.js +1 -1
  106. package/dist/heart/machine-identity.js +161 -0
  107. package/dist/heart/mail-import-discovery.js +353 -0
  108. package/dist/heart/mcp/mcp-server.js +653 -0
  109. package/dist/heart/migrate-config.js +100 -0
  110. package/dist/heart/model-capabilities.js +59 -0
  111. package/dist/heart/outlook/outlook-http-hooks.js +66 -0
  112. package/dist/heart/outlook/outlook-http-response.js +7 -0
  113. package/dist/heart/outlook/outlook-http-routes.js +244 -0
  114. package/dist/heart/outlook/outlook-http-static.js +103 -0
  115. package/dist/heart/outlook/outlook-http-transport.js +116 -0
  116. package/dist/heart/outlook/outlook-http.js +99 -0
  117. package/dist/heart/outlook/outlook-read.js +31 -0
  118. package/dist/heart/outlook/outlook-types.js +27 -0
  119. package/dist/heart/outlook/outlook-view.js +195 -0
  120. package/dist/heart/outlook/readers/agent-machine.js +382 -0
  121. package/dist/heart/outlook/readers/continuity-readers.js +336 -0
  122. package/dist/heart/outlook/readers/mail.js +362 -0
  123. package/dist/heart/outlook/readers/runtime-readers.js +644 -0
  124. package/dist/heart/outlook/readers/sessions.js +232 -0
  125. package/dist/heart/outlook/readers/shared.js +111 -0
  126. package/dist/heart/platform.js +81 -0
  127. package/dist/heart/provider-attempt.js +134 -0
  128. package/dist/heart/provider-binding-resolver.js +255 -0
  129. package/dist/heart/provider-credentials.js +424 -0
  130. package/dist/heart/provider-failover.js +301 -0
  131. package/dist/heart/provider-models.js +81 -0
  132. package/dist/heart/provider-ping.js +262 -0
  133. package/dist/heart/provider-state.js +216 -0
  134. package/dist/heart/provider-visibility.js +188 -0
  135. package/dist/heart/providers/anthropic-token.js +131 -0
  136. package/dist/heart/providers/anthropic.js +193 -55
  137. package/dist/heart/providers/azure.js +104 -13
  138. package/dist/heart/providers/error-classification.js +63 -0
  139. package/dist/heart/providers/github-copilot.js +145 -0
  140. package/dist/heart/providers/minimax-vlm.js +189 -0
  141. package/dist/heart/providers/minimax.js +29 -7
  142. package/dist/heart/providers/openai-codex.js +63 -39
  143. package/dist/heart/runtime-capability-check.js +170 -0
  144. package/dist/heart/runtime-credentials.js +260 -0
  145. package/dist/heart/sense-truth.js +11 -4
  146. package/dist/heart/session-activity.js +43 -22
  147. package/dist/heart/session-events.js +1089 -0
  148. package/dist/heart/session-playback-cli-main.js +5 -0
  149. package/dist/heart/session-playback-cli.js +36 -0
  150. package/dist/heart/session-playback.js +231 -0
  151. package/dist/heart/session-transcript.js +167 -0
  152. package/dist/heart/start-of-turn-packet.js +345 -0
  153. package/dist/heart/streaming.js +48 -28
  154. package/dist/heart/sync.js +332 -0
  155. package/dist/heart/target-resolution.js +127 -0
  156. package/dist/heart/tempo.js +93 -0
  157. package/dist/heart/temporal-view.js +41 -0
  158. package/dist/heart/tool-activity-callbacks.js +36 -0
  159. package/dist/heart/tool-description.js +135 -0
  160. package/dist/heart/tool-friction.js +55 -0
  161. package/dist/heart/tool-loop.js +200 -0
  162. package/dist/heart/turn-context.js +372 -0
  163. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +1 -1
  164. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  165. package/dist/heart/versioning/ouro-path-installer.js +425 -0
  166. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  167. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  168. package/dist/heart/{daemon → versioning}/update-checker.js +5 -1
  169. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  170. package/dist/mailroom/attention.js +167 -0
  171. package/dist/mailroom/autonomy.js +209 -0
  172. package/dist/mailroom/blob-store.js +606 -0
  173. package/dist/mailroom/core.js +672 -0
  174. package/dist/mailroom/entry.js +160 -0
  175. package/dist/mailroom/file-store.js +426 -0
  176. package/dist/mailroom/mbox-import.js +382 -0
  177. package/dist/mailroom/outbound.js +380 -0
  178. package/dist/mailroom/policy.js +263 -0
  179. package/dist/mailroom/reader.js +219 -0
  180. package/dist/mailroom/search-cache.js +182 -0
  181. package/dist/mailroom/search-relevance.js +319 -0
  182. package/dist/mailroom/smtp-ingress.js +176 -0
  183. package/dist/mailroom/source-state.js +176 -0
  184. package/dist/mailroom/thread.js +109 -0
  185. package/dist/mailroom/travel-extract.js +89 -0
  186. package/dist/mind/bundle-manifest.js +7 -1
  187. package/dist/mind/context.js +164 -101
  188. package/dist/mind/diary-integrity.js +60 -0
  189. package/dist/mind/{memory.js → diary.js} +74 -93
  190. package/dist/mind/embedding-provider.js +60 -0
  191. package/dist/mind/file-state.js +179 -0
  192. package/dist/mind/friends/channel.js +30 -0
  193. package/dist/mind/friends/group-context.js +144 -0
  194. package/dist/mind/friends/resolver.js +54 -2
  195. package/dist/mind/friends/store-file.js +39 -3
  196. package/dist/mind/friends/trust-explanation.js +74 -0
  197. package/dist/mind/friends/types.js +2 -2
  198. package/dist/mind/journal-index.js +161 -0
  199. package/dist/mind/note-search.js +268 -0
  200. package/dist/mind/obligation-steering.js +221 -0
  201. package/dist/mind/pending.js +4 -0
  202. package/dist/mind/prompt-refresh.js +3 -2
  203. package/dist/mind/prompt.js +948 -110
  204. package/dist/mind/provenance-trust.js +26 -0
  205. package/dist/mind/scrutiny.js +173 -0
  206. package/dist/nerves/cli-logging.js +7 -1
  207. package/dist/nerves/coverage/audit-rules.js +15 -6
  208. package/dist/nerves/coverage/audit.js +28 -2
  209. package/dist/nerves/coverage/cli.js +1 -1
  210. package/dist/nerves/coverage/contract.js +5 -5
  211. package/dist/nerves/coverage/file-completeness.js +106 -5
  212. package/dist/nerves/coverage/run-artifacts.js +1 -1
  213. package/dist/nerves/event-buffer.js +111 -0
  214. package/dist/nerves/index.js +224 -4
  215. package/dist/nerves/observation.js +20 -0
  216. package/dist/nerves/redact.js +79 -0
  217. package/dist/nerves/review/cli-main.js +5 -0
  218. package/dist/nerves/review/cli.js +156 -0
  219. package/dist/nerves/review/core.js +152 -0
  220. package/dist/nerves/runtime.js +5 -1
  221. package/dist/outlook-ui/assets/index-BPr5vNuM.css +1 -0
  222. package/dist/outlook-ui/assets/index-Cm51CY9W.js +61 -0
  223. package/dist/outlook-ui/index.html +15 -0
  224. package/dist/repertoire/ado-client.js +15 -56
  225. package/dist/repertoire/ado-semantic.js +11 -10
  226. package/dist/repertoire/api-client.js +97 -0
  227. package/dist/repertoire/bitwarden-store.js +774 -0
  228. package/dist/repertoire/bundle-templates.js +72 -0
  229. package/dist/repertoire/bw-installer.js +180 -0
  230. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  231. package/dist/repertoire/coding/context-pack.js +330 -0
  232. package/dist/repertoire/coding/feedback.js +197 -30
  233. package/dist/repertoire/coding/manager.js +158 -9
  234. package/dist/repertoire/coding/spawner.js +55 -9
  235. package/dist/repertoire/coding/tools.js +170 -7
  236. package/dist/repertoire/commerce-errors.js +109 -0
  237. package/dist/repertoire/commerce-self-test.js +156 -0
  238. package/dist/repertoire/credential-access.js +111 -0
  239. package/dist/repertoire/duffel-client.js +185 -0
  240. package/dist/repertoire/github-client.js +14 -55
  241. package/dist/repertoire/graph-client.js +11 -52
  242. package/dist/repertoire/guardrails.js +396 -0
  243. package/dist/repertoire/mcp-client.js +255 -0
  244. package/dist/repertoire/mcp-manager.js +305 -0
  245. package/dist/repertoire/mcp-tools.js +63 -0
  246. package/dist/repertoire/shell-sessions.js +133 -0
  247. package/dist/repertoire/skills.js +15 -24
  248. package/dist/repertoire/stripe-client.js +131 -0
  249. package/dist/repertoire/tasks/board.js +31 -5
  250. package/dist/repertoire/tasks/fix.js +182 -0
  251. package/dist/repertoire/tasks/index.js +16 -4
  252. package/dist/repertoire/tasks/lifecycle.js +2 -2
  253. package/dist/repertoire/tasks/parser.js +3 -2
  254. package/dist/repertoire/tasks/scanner.js +194 -37
  255. package/dist/repertoire/tasks/transitions.js +16 -78
  256. package/dist/repertoire/tool-results.js +29 -0
  257. package/dist/repertoire/tools-attachments.js +317 -0
  258. package/dist/repertoire/tools-base.js +46 -921
  259. package/dist/repertoire/tools-bluebubbles.js +1 -0
  260. package/dist/repertoire/tools-bridge.js +141 -0
  261. package/dist/repertoire/tools-bundle.js +984 -0
  262. package/dist/repertoire/tools-config.js +185 -0
  263. package/dist/repertoire/tools-continuity.js +248 -0
  264. package/dist/repertoire/tools-credential.js +381 -0
  265. package/dist/repertoire/tools-files.js +342 -0
  266. package/dist/repertoire/tools-flight.js +224 -0
  267. package/dist/repertoire/tools-flow.js +105 -0
  268. package/dist/repertoire/tools-github.js +1 -7
  269. package/dist/repertoire/tools-mail.js +1377 -0
  270. package/dist/repertoire/tools-notes.js +376 -0
  271. package/dist/repertoire/tools-session.js +749 -0
  272. package/dist/repertoire/tools-shell.js +120 -0
  273. package/dist/repertoire/tools-stripe.js +180 -0
  274. package/dist/repertoire/tools-surface.js +243 -0
  275. package/dist/repertoire/tools-teams.js +9 -39
  276. package/dist/repertoire/tools-travel.js +125 -0
  277. package/dist/repertoire/tools-trip.js +356 -0
  278. package/dist/repertoire/tools-user-profile.js +144 -0
  279. package/dist/repertoire/tools-vault.js +40 -0
  280. package/dist/repertoire/tools.js +144 -115
  281. package/dist/repertoire/travel-api-client.js +360 -0
  282. package/dist/repertoire/user-profile.js +131 -0
  283. package/dist/repertoire/vault-setup.js +246 -0
  284. package/dist/repertoire/vault-unlock.js +561 -0
  285. package/dist/scripts/claude-code-hook.js +41 -0
  286. package/dist/scripts/claude-code-stop-hook.js +47 -0
  287. package/dist/senses/attention-queue.js +116 -0
  288. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  289. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  290. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
  291. package/dist/senses/bluebubbles/entry.js +73 -0
  292. package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
  293. package/dist/senses/bluebubbles/index.js +1881 -0
  294. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  295. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
  296. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
  297. package/dist/senses/bluebubbles/processed-log.js +111 -0
  298. package/dist/senses/bluebubbles/replay.js +129 -0
  299. package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +2 -2
  300. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  301. package/dist/senses/cli/bracketed-paste.js +82 -0
  302. package/dist/senses/cli/image-paste.js +287 -0
  303. package/dist/senses/cli/image-ref-navigation.js +75 -0
  304. package/dist/senses/cli/ink-app.js +156 -0
  305. package/dist/senses/cli/inline-diff.js +64 -0
  306. package/dist/senses/cli/input-keys.js +174 -0
  307. package/dist/senses/cli/kill-ring.js +86 -0
  308. package/dist/senses/cli/message-list.js +51 -0
  309. package/dist/senses/cli/ouro-tui.js +605 -0
  310. package/dist/senses/cli/spinner-imperative.js +135 -0
  311. package/dist/senses/cli/spinner.js +101 -0
  312. package/dist/senses/cli/status-line.js +60 -0
  313. package/dist/senses/cli/streaming-markdown.js +526 -0
  314. package/dist/senses/cli/tool-display.js +83 -0
  315. package/dist/senses/cli/tool-render.js +85 -0
  316. package/dist/senses/cli/tui-store.js +240 -0
  317. package/dist/senses/cli/virtual-list.js +35 -0
  318. package/dist/senses/cli-entry.js +60 -8
  319. package/dist/senses/cli-layout.js +187 -0
  320. package/dist/senses/cli.js +511 -209
  321. package/dist/senses/commands.js +66 -3
  322. package/dist/senses/habit-turn-message.js +108 -0
  323. package/dist/senses/inner-dialog-worker.js +175 -21
  324. package/dist/senses/inner-dialog.js +330 -27
  325. package/dist/senses/mail-entry.js +66 -0
  326. package/dist/senses/mail.js +379 -0
  327. package/dist/senses/pipeline.js +573 -164
  328. package/dist/senses/proactive-content-guard.js +51 -0
  329. package/dist/senses/shared-turn.js +248 -0
  330. package/dist/senses/surface-tool.js +68 -0
  331. package/dist/senses/teams-entry.js +60 -8
  332. package/dist/senses/teams.js +405 -170
  333. package/dist/senses/trust-gate.js +100 -5
  334. package/dist/trips/core.js +138 -0
  335. package/dist/trips/store.js +146 -0
  336. package/package.json +39 -8
  337. package/skills/agent-commerce.md +106 -0
  338. package/skills/browser-navigation.md +117 -0
  339. package/skills/commerce-setup-guide.md +116 -0
  340. package/skills/commerce-setup.md +84 -0
  341. package/skills/configure-dev-tools.md +101 -0
  342. package/skills/travel-planning.md +138 -0
  343. package/dist/heart/daemon/ouro-path-installer.js +0 -178
  344. package/dist/heart/daemon/subagent-installer.js +0 -166
  345. package/dist/heart/session-recall.js +0 -116
  346. package/dist/mind/associative-recall.js +0 -209
  347. package/dist/senses/bluebubbles-entry.js +0 -13
  348. package/dist/senses/bluebubbles.js +0 -1142
  349. package/dist/senses/debug-activity.js +0 -148
  350. package/subagents/README.md +0 -86
  351. package/subagents/work-doer.md +0 -237
  352. package/subagents/work-merger.md +0 -618
  353. package/subagents/work-planner.md +0 -390
  354. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  355. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  356. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  357. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  358. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  359. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  360. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  361. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  362. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  363. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  364. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  365. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  366. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  367. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  368. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  369. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +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,490 @@
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 machine_identity_1 = require("../machine-identity");
45
+ const provider_state_1 = require("../provider-state");
46
+ const provider_credentials_1 = require("../provider-credentials");
47
+ const vault_unlock_1 = require("../../repertoire/vault-unlock");
48
+ const readiness_repair_1 = require("./readiness-repair");
49
+ const provider_ping_progress_1 = require("./provider-ping-progress");
50
+ function isAgentProvider(value) {
51
+ return Object.prototype.hasOwnProperty.call(identity_1.PROVIDER_CREDENTIALS, value);
52
+ }
53
+ function agentRootFor(agentName, bundlesRoot) {
54
+ return path.join(bundlesRoot, `${agentName}.ouro`);
55
+ }
56
+ function configPathFor(agentName, bundlesRoot) {
57
+ return path.join(agentRootFor(agentName, bundlesRoot), "agent.json");
58
+ }
59
+ function resolveFacingProvider(parsed, facing, agentName, agentJsonPath) {
60
+ const raw = parsed[facing];
61
+ if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
62
+ return {
63
+ ok: false,
64
+ result: {
65
+ ok: false,
66
+ error: `agent.json for '${agentName}' is missing ${facing}.provider`,
67
+ fix: `Add ${facing}: { provider, model } to ${agentJsonPath}. Valid providers: ${Object.keys(identity_1.PROVIDER_CREDENTIALS).join(", ")}`,
68
+ },
69
+ };
70
+ }
71
+ const provider = raw.provider;
72
+ if (typeof provider !== "string" || provider.length === 0) {
73
+ return {
74
+ ok: false,
75
+ result: {
76
+ ok: false,
77
+ error: `agent.json for '${agentName}' is missing ${facing}.provider`,
78
+ fix: `Set ${facing}.provider in ${agentJsonPath}. Valid providers: ${Object.keys(identity_1.PROVIDER_CREDENTIALS).join(", ")}`,
79
+ },
80
+ };
81
+ }
82
+ if (!isAgentProvider(provider)) {
83
+ return {
84
+ ok: false,
85
+ result: {
86
+ ok: false,
87
+ error: `Unknown provider '${provider}' in ${facing}.provider for '${agentName}'`,
88
+ fix: `Set ${facing}.provider to one of: ${Object.keys(identity_1.PROVIDER_CREDENTIALS).join(", ")}`,
89
+ },
90
+ };
91
+ }
92
+ return { ok: true, selected: { facing, provider } };
93
+ }
94
+ function readAgentConfigForProviderState(agentName, bundlesRoot) {
95
+ const agentJsonPath = configPathFor(agentName, bundlesRoot);
96
+ let raw;
97
+ try {
98
+ raw = fs.readFileSync(agentJsonPath, "utf-8");
99
+ }
100
+ catch {
101
+ return {
102
+ ok: false,
103
+ result: {
104
+ ok: false,
105
+ error: `agent.json not found at ${agentJsonPath}`,
106
+ fix: `Run 'ouro hatch ${agentName}' to create the agent bundle, or verify that ${bundlesRoot}/${agentName}.ouro/ exists.`,
107
+ },
108
+ };
109
+ }
110
+ let parsed;
111
+ try {
112
+ parsed = JSON.parse(raw);
113
+ }
114
+ catch {
115
+ return {
116
+ ok: false,
117
+ result: {
118
+ ok: false,
119
+ error: `agent.json at ${agentJsonPath} contains invalid JSON`,
120
+ fix: `Open ${agentJsonPath} and fix the JSON syntax.`,
121
+ },
122
+ };
123
+ }
124
+ if (parsed.enabled === false) {
125
+ return { ok: true, disabled: true, agentJsonPath, parsed };
126
+ }
127
+ return { ok: true, disabled: false, agentJsonPath, parsed };
128
+ }
129
+ function readFacingForBootstrap(parsed, facing, agentName, agentJsonPath) {
130
+ const providerResult = resolveFacingProvider(parsed, facing, agentName, agentJsonPath);
131
+ if (!providerResult.ok) {
132
+ return {
133
+ ok: false,
134
+ result: {
135
+ ok: false,
136
+ error: providerResult.result.error,
137
+ fix: `Run 'ouro use --agent ${agentName} --lane ${facing === "humanFacing" ? "outward" : "inner"} --provider <provider> --model <model>' to configure this machine's provider binding.`,
138
+ },
139
+ };
140
+ }
141
+ const raw = parsed[facing];
142
+ const model = typeof raw.model === "string" && raw.model.trim().length > 0
143
+ ? raw.model.trim()
144
+ : (0, provider_models_1.getDefaultModelForProvider)(providerResult.selected.provider);
145
+ return { ok: true, provider: providerResult.selected.provider, model };
146
+ }
147
+ function bootstrapMissingProviderState(input) {
148
+ const outward = readFacingForBootstrap(input.parsed, "humanFacing", input.agentName, input.agentJsonPath);
149
+ if (!outward.ok)
150
+ return { ok: false, error: outward.result.error, fix: outward.result.fix };
151
+ const inner = readFacingForBootstrap(input.parsed, "agentFacing", input.agentName, input.agentJsonPath);
152
+ if (!inner.ok)
153
+ return { ok: false, error: inner.result.error, fix: inner.result.fix };
154
+ const now = new Date();
155
+ const homeDir = (0, provider_credentials_1.providerCredentialMachineHomeDir)(input.homeDir);
156
+ const machine = (0, machine_identity_1.loadOrCreateMachineIdentity)({ homeDir, now: () => now });
157
+ const state = (0, provider_state_1.bootstrapProviderStateFromAgentConfig)({
158
+ machineId: machine.machineId,
159
+ now,
160
+ agentConfig: {
161
+ humanFacing: { provider: outward.provider, model: outward.model },
162
+ agentFacing: { provider: inner.provider, model: inner.model },
163
+ },
164
+ });
165
+ const agentRoot = agentRootFor(input.agentName, input.bundlesRoot);
166
+ (0, provider_state_1.writeProviderState)(agentRoot, state);
167
+ (0, runtime_1.emitNervesEvent)({
168
+ component: "daemon",
169
+ event: "daemon.provider_state_bootstrapped",
170
+ message: "bootstrapped local provider state from agent config",
171
+ meta: { agent: input.agentName, agentRoot },
172
+ });
173
+ return { ok: true, agentRoot, state };
174
+ }
175
+ function readOrBootstrapProviderStateForCheck(agentName, bundlesRoot, deps = {}) {
176
+ const configResult = readAgentConfigForProviderState(agentName, bundlesRoot);
177
+ if (!configResult.ok)
178
+ return { ok: false, result: configResult.result };
179
+ if (configResult.disabled)
180
+ return { ok: true, disabled: true };
181
+ const agentRoot = agentRootFor(agentName, bundlesRoot);
182
+ const stateResult = (0, provider_state_1.readProviderState)(agentRoot);
183
+ if (stateResult.ok) {
184
+ return { ok: true, disabled: false, agentRoot, state: stateResult.state };
185
+ }
186
+ if (stateResult.reason === "invalid") {
187
+ return {
188
+ ok: false,
189
+ result: {
190
+ ok: false,
191
+ error: `provider state for ${agentName} is invalid at ${stateResult.statePath}: ${stateResult.error}`,
192
+ fix: `Run 'ouro use --agent ${agentName} --lane outward --provider <provider> --model <model> --force' to rewrite this machine's provider binding.`,
193
+ },
194
+ };
195
+ }
196
+ const bootstrap = bootstrapMissingProviderState({
197
+ agentName,
198
+ bundlesRoot,
199
+ parsed: configResult.parsed,
200
+ agentJsonPath: configResult.agentJsonPath,
201
+ homeDir: deps.homeDir,
202
+ });
203
+ if (!bootstrap.ok)
204
+ return { ok: false, result: bootstrap };
205
+ return { ok: true, disabled: false, agentRoot: bootstrap.agentRoot, state: bootstrap.state };
206
+ }
207
+ function providerCredentialConfig(record) {
208
+ return {
209
+ ...record.credentials,
210
+ ...record.config,
211
+ };
212
+ }
213
+ function pingAttemptCount(result) {
214
+ if (Array.isArray(result.attempts))
215
+ return result.attempts.length;
216
+ return undefined;
217
+ }
218
+ function writeLaneReadiness(input) {
219
+ const binding = input.state.lanes[input.lane];
220
+ const checkedAt = new Date().toISOString();
221
+ input.state.updatedAt = checkedAt;
222
+ input.state.readiness[input.lane] = {
223
+ status: input.status,
224
+ provider: binding.provider,
225
+ model: binding.model,
226
+ checkedAt,
227
+ credentialRevision: input.credentialRevision,
228
+ ...(input.error ? { error: input.error } : {}),
229
+ ...(input.attempts !== undefined ? { attempts: input.attempts } : {}),
230
+ };
231
+ (0, provider_state_1.writeProviderState)(input.agentRoot, input.state);
232
+ }
233
+ function missingCredentialResult(agentName, lane, provider, model, credentialPath) {
234
+ return {
235
+ ok: false,
236
+ error: `${lane} provider ${provider} model ${model} has no credentials in ${agentName}'s vault at ${credentialPath}`,
237
+ fix: `Run 'ouro auth --agent ${agentName} --provider ${provider}' to authenticate.`,
238
+ issue: (0, readiness_repair_1.providerCredentialMissingIssue)({
239
+ agentName,
240
+ lane,
241
+ provider,
242
+ model,
243
+ credentialPath,
244
+ }),
245
+ };
246
+ }
247
+ function isTransientVaultError(error) {
248
+ const normalized = error.toLowerCase();
249
+ return (normalized.includes("timed out") ||
250
+ normalized.includes("econnrefused") ||
251
+ normalized.includes("socket hang up") ||
252
+ normalized.includes("etimedout"));
253
+ }
254
+ function invalidPoolResult(agentName, lane, provider, model, pool) {
255
+ if (pool.reason === "unavailable" && isTransientVaultError(pool.error)) {
256
+ return {
257
+ ok: false,
258
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials from ${agentName}'s vault: ${pool.error}`,
259
+ fix: `Vault read timed out -- this usually resolves on retry. Run 'ouro up' again.`,
260
+ };
261
+ }
262
+ if (pool.reason === "unavailable" && isVaultLockedError(pool.error)) {
263
+ return {
264
+ ok: false,
265
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials because ${agentName}'s credential vault is locked on this machine.`,
266
+ fix: vaultUnlockOrRecoverFix(agentName),
267
+ issue: (0, readiness_repair_1.vaultLockedIssue)(agentName),
268
+ };
269
+ }
270
+ if (pool.reason === "unavailable" && (0, vault_unlock_1.isCredentialVaultNotConfiguredError)(pool.error)) {
271
+ return {
272
+ ok: false,
273
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials because ${agentName}'s credential vault is not configured in agent.json.`,
274
+ fix: (0, vault_unlock_1.vaultCreateRecoverFix)(agentName, `Then run 'ouro auth --agent ${agentName} --provider ${provider}' and rerun 'ouro up'.`),
275
+ issue: (0, readiness_repair_1.vaultUnconfiguredIssue)(agentName),
276
+ };
277
+ }
278
+ if (pool.reason === "invalid") {
279
+ return {
280
+ ok: false,
281
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials from ${agentName}'s vault at ${pool.poolPath}: ${pool.error}`,
282
+ fix: `Run 'ouro auth --agent ${agentName} --provider ${provider}' to rewrite this provider credential, then run 'ouro up' again.`,
283
+ };
284
+ }
285
+ return {
286
+ ok: false,
287
+ error: `${lane} provider ${provider} model ${model} cannot read provider credentials from ${agentName}'s vault at ${pool.poolPath}: ${pool.error}`,
288
+ 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}'.`),
289
+ };
290
+ }
291
+ function isVaultLockedError(error) {
292
+ const normalized = error.toLowerCase();
293
+ return /(?:ouro )?credential vault is locked|vault(?: is)? locked/.test(normalized);
294
+ }
295
+ function vaultUnlockOrRecoverFix(agentName, nextStep = "Then run 'ouro up' again.") {
296
+ return (0, vault_unlock_1.vaultUnlockReplaceRecoverFix)(agentName, nextStep);
297
+ }
298
+ function failedPingResult(agentName, lane, provider, model, result) {
299
+ return {
300
+ ok: false,
301
+ error: `${lane} provider ${provider} model ${model} failed live check: ${result.message}`,
302
+ fix: (0, readiness_repair_1.providerLiveCheckFix)({
303
+ agentName,
304
+ lane,
305
+ provider,
306
+ classification: result.classification,
307
+ }),
308
+ issue: (0, readiness_repair_1.providerLiveCheckFailedIssue)({
309
+ agentName,
310
+ lane,
311
+ provider,
312
+ model,
313
+ classification: result.classification,
314
+ message: result.message,
315
+ }),
316
+ };
317
+ }
318
+ function credentialRecordForLane(pool, provider) {
319
+ return pool.providers[provider];
320
+ }
321
+ function laneAudienceLabel(lane) {
322
+ return lane === "outward" ? "chat" : "inner dialog";
323
+ }
324
+ function bindingLabel(binding) {
325
+ return `${binding.provider} / ${binding.model}`;
326
+ }
327
+ function selectedProviderPlan(agentName, state) {
328
+ return [
329
+ `${agentName}: checking the providers this agent uses right now`,
330
+ ...["outward", "inner"].map((lane) => `- ${laneAudienceLabel(lane)}: ${bindingLabel(state.lanes[lane])}`),
331
+ ].join("\n");
332
+ }
333
+ function selectedProvidersForState(state) {
334
+ return [...new Set(["outward", "inner"].map((lane) => state.lanes[lane].provider))];
335
+ }
336
+ function mapVaultRefreshProgress(agentName, onProgress) {
337
+ return (message) => {
338
+ if (message.startsWith("reading vault items for ")) {
339
+ onProgress(`${agentName}: opening saved provider credentials in the vault`);
340
+ return;
341
+ }
342
+ const providerRead = message.match(/^reading ([a-z0-9-]+) credentials\.\.\.$/i);
343
+ if (providerRead) {
344
+ onProgress(`${agentName}: reading saved ${providerRead[1]} credentials`);
345
+ return;
346
+ }
347
+ if (message === "parsing provider credentials...") {
348
+ onProgress(`${agentName}: organizing saved provider credentials`);
349
+ }
350
+ };
351
+ }
352
+ function providerPingSubject(agentName, lanes) {
353
+ const laneList = lanes.map((lane) => laneAudienceLabel(lane)).join(" + ");
354
+ return `${agentName} (${laneList})`;
355
+ }
356
+ /**
357
+ * Structural validation only. Live provider credential validation belongs to
358
+ * checkAgentConfigWithProviderHealth(), which reads the agent vault and pings.
359
+ */
360
+ function checkAgentConfig(agentName, bundlesRoot) {
361
+ const configResult = readAgentConfigForProviderState(agentName, bundlesRoot);
362
+ if (!configResult.ok)
363
+ return configResult.result;
364
+ if (configResult.disabled)
365
+ return { ok: true };
366
+ const outward = readFacingForBootstrap(configResult.parsed, "humanFacing", agentName, configResult.agentJsonPath);
367
+ if (!outward.ok)
368
+ return outward.result;
369
+ const inner = readFacingForBootstrap(configResult.parsed, "agentFacing", agentName, configResult.agentJsonPath);
370
+ if (!inner.ok)
371
+ return inner.result;
372
+ (0, runtime_1.emitNervesEvent)({
373
+ component: "daemon",
374
+ event: "daemon.agent_config_valid",
375
+ message: "agent config validation passed",
376
+ meta: {
377
+ agent: agentName,
378
+ providers: [...new Set([outward.provider, inner.provider])],
379
+ liveProviderCheck: false,
380
+ },
381
+ });
382
+ return { ok: true };
383
+ }
384
+ async function checkAgentConfigWithProviderHealth(agentName, bundlesRoot, deps = {}) {
385
+ const stateResult = readOrBootstrapProviderStateForCheck(agentName, bundlesRoot, deps);
386
+ if (!stateResult.ok)
387
+ return stateResult.result;
388
+ if (stateResult.disabled)
389
+ return { ok: true };
390
+ deps.onProgress?.(selectedProviderPlan(agentName, stateResult.state));
391
+ const ping = deps.pingProvider ?? (await Promise.resolve().then(() => __importStar(require("../provider-ping")))).pingProvider;
392
+ const shouldRecordReadiness = deps.recordReadiness ?? true;
393
+ const providers = selectedProvidersForState(stateResult.state);
394
+ const poolResult = await (0, provider_credentials_1.refreshProviderCredentialPool)(agentName, {
395
+ ...(deps.onProgress ? { onProgress: mapVaultRefreshProgress(agentName, deps.onProgress) } : {}),
396
+ providers,
397
+ skipCache: true,
398
+ });
399
+ const pingGroups = new Map();
400
+ const lanes = ["outward", "inner"];
401
+ for (const lane of lanes) {
402
+ const binding = stateResult.state.lanes[lane];
403
+ if (!poolResult.ok) {
404
+ if (poolResult.reason === "missing") {
405
+ return missingCredentialResult(agentName, lane, binding.provider, binding.model, poolResult.poolPath);
406
+ }
407
+ return invalidPoolResult(agentName, lane, binding.provider, binding.model, {
408
+ ...poolResult,
409
+ reason: poolResult.reason,
410
+ });
411
+ }
412
+ const record = credentialRecordForLane(poolResult.pool, binding.provider);
413
+ if (!record) {
414
+ return missingCredentialResult(agentName, lane, binding.provider, binding.model, poolResult.poolPath);
415
+ }
416
+ const key = `${binding.provider}\0${binding.model}\0${record.revision}`;
417
+ const group = pingGroups.get(key);
418
+ if (group) {
419
+ group.lanes.push(lane);
420
+ }
421
+ else {
422
+ pingGroups.set(key, {
423
+ provider: binding.provider,
424
+ model: binding.model,
425
+ record,
426
+ lanes: [lane],
427
+ });
428
+ }
429
+ }
430
+ const groups = [...pingGroups.values()];
431
+ const pingResults = await Promise.all(groups.map(async (group) => {
432
+ const result = await ping(group.provider, providerCredentialConfig(group.record), {
433
+ model: group.model,
434
+ ...(deps.providerPingOptions ?? {}),
435
+ ...(deps.onProgress
436
+ ? (0, provider_ping_progress_1.createProviderPingProgressReporter)({
437
+ provider: group.provider,
438
+ model: group.model,
439
+ subject: providerPingSubject(agentName, group.lanes),
440
+ }, deps.onProgress)
441
+ : {}),
442
+ });
443
+ return { group, result };
444
+ }));
445
+ let firstFailure = null;
446
+ for (const { group, result } of pingResults) {
447
+ if (!result.ok) {
448
+ if (shouldRecordReadiness) {
449
+ for (const lane of group.lanes) {
450
+ writeLaneReadiness({
451
+ agentRoot: stateResult.agentRoot,
452
+ state: stateResult.state,
453
+ lane,
454
+ status: "failed",
455
+ credentialRevision: group.record.revision,
456
+ error: result.message,
457
+ attempts: pingAttemptCount(result),
458
+ });
459
+ }
460
+ }
461
+ firstFailure ??= failedPingResult(agentName, group.lanes[0], group.provider, group.model, result);
462
+ continue;
463
+ }
464
+ if (shouldRecordReadiness) {
465
+ for (const lane of group.lanes) {
466
+ writeLaneReadiness({
467
+ agentRoot: stateResult.agentRoot,
468
+ state: stateResult.state,
469
+ lane,
470
+ status: "ready",
471
+ credentialRevision: group.record.revision,
472
+ attempts: pingAttemptCount(result),
473
+ });
474
+ }
475
+ }
476
+ }
477
+ if (firstFailure)
478
+ return firstFailure;
479
+ (0, runtime_1.emitNervesEvent)({
480
+ component: "daemon",
481
+ event: "daemon.agent_config_valid",
482
+ message: "agent config validation passed",
483
+ meta: {
484
+ agent: agentName,
485
+ providers: [...new Set([...pingGroups.values()].map((group) => group.provider))],
486
+ liveProviderCheck: true,
487
+ },
488
+ });
489
+ return { ok: true };
490
+ }