@ouro.bot/cli 0.1.0-alpha.55 → 0.1.0-alpha.551

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 (386) hide show
  1. package/README.md +133 -19
  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-bootstrap-drift.md +54 -0
  6. package/RepairGuide.ouro/skills/diagnose-broken-remote.md +63 -0
  7. package/RepairGuide.ouro/skills/diagnose-stacked-typed-issues.md +35 -0
  8. package/RepairGuide.ouro/skills/diagnose-sync-blocked.md +54 -0
  9. package/RepairGuide.ouro/skills/diagnose-vault-expired.md +60 -0
  10. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +4 -2
  11. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
  12. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  13. package/changelog.json +3561 -0
  14. package/dist/arc/attention-types.js +8 -0
  15. package/dist/arc/cares.js +140 -0
  16. package/dist/arc/episodes.js +117 -0
  17. package/dist/arc/intentions.js +133 -0
  18. package/dist/arc/json-store.js +117 -0
  19. package/dist/arc/obligations.js +237 -0
  20. package/dist/arc/packets.js +193 -0
  21. package/dist/arc/presence.js +185 -0
  22. package/dist/arc/task-lifecycle.js +65 -0
  23. package/dist/heart/active-work.js +837 -26
  24. package/dist/heart/agent-entry.js +58 -3
  25. package/dist/heart/attachments/image-normalize.js +194 -0
  26. package/dist/heart/attachments/materialize.js +97 -0
  27. package/dist/heart/attachments/originals.js +88 -0
  28. package/dist/heart/attachments/render.js +29 -0
  29. package/dist/heart/attachments/sources/adapter.js +2 -0
  30. package/dist/heart/attachments/sources/bluebubbles.js +156 -0
  31. package/dist/heart/attachments/sources/cli-local-file.js +78 -0
  32. package/dist/heart/attachments/sources/index.js +16 -0
  33. package/dist/heart/attachments/store.js +103 -0
  34. package/dist/heart/attachments/types.js +93 -0
  35. package/dist/heart/auth/auth-flow.js +479 -0
  36. package/dist/heart/background-operations.js +281 -0
  37. package/dist/heart/bundle-state.js +168 -0
  38. package/dist/heart/commitments.js +111 -0
  39. package/dist/heart/config-registry.js +304 -0
  40. package/dist/heart/config.js +114 -118
  41. package/dist/heart/core.js +925 -246
  42. package/dist/heart/cross-chat-delivery.js +3 -18
  43. package/dist/heart/daemon/agent-config-check.js +512 -0
  44. package/dist/heart/daemon/agent-discovery.js +102 -3
  45. package/dist/heart/daemon/agent-service.js +522 -0
  46. package/dist/heart/daemon/agentic-repair.js +554 -0
  47. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  48. package/dist/heart/daemon/boot-sync-probe.js +197 -0
  49. package/dist/heart/daemon/cadence.js +70 -0
  50. package/dist/heart/daemon/cli-defaults.js +665 -0
  51. package/dist/heart/daemon/cli-exec.js +7565 -0
  52. package/dist/heart/daemon/cli-help.js +498 -0
  53. package/dist/heart/daemon/cli-parse.js +1590 -0
  54. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  55. package/dist/heart/daemon/cli-render.js +775 -0
  56. package/dist/heart/daemon/cli-types.js +8 -0
  57. package/dist/heart/daemon/connect-bay.js +323 -0
  58. package/dist/heart/daemon/daemon-cli.js +29 -1672
  59. package/dist/heart/daemon/daemon-entry.js +417 -2
  60. package/dist/heart/daemon/daemon-health.js +183 -0
  61. package/dist/heart/daemon/daemon-rollup.js +58 -0
  62. package/dist/heart/daemon/daemon-runtime-sync.js +87 -13
  63. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  64. package/dist/heart/daemon/daemon.js +796 -71
  65. package/dist/heart/daemon/dns-workflow.js +394 -0
  66. package/dist/heart/daemon/doctor-types.js +8 -0
  67. package/dist/heart/daemon/doctor.js +844 -0
  68. package/dist/heart/daemon/drift-detection.js +146 -0
  69. package/dist/heart/daemon/health-monitor.js +122 -1
  70. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  71. package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
  72. package/dist/heart/daemon/http-health-probe.js +80 -0
  73. package/dist/heart/daemon/human-command-screens.js +234 -0
  74. package/dist/heart/daemon/human-readiness.js +114 -0
  75. package/dist/heart/daemon/inner-status.js +102 -0
  76. package/dist/heart/daemon/interactive-repair.js +394 -0
  77. package/dist/heart/daemon/launchd.js +37 -8
  78. package/dist/heart/daemon/log-tailer.js +82 -12
  79. package/dist/heart/daemon/logs-prune.js +110 -0
  80. package/dist/heart/daemon/mcp-canary.js +297 -0
  81. package/dist/heart/daemon/message-router.js +2 -2
  82. package/dist/heart/daemon/os-cron-deps.js +135 -0
  83. package/dist/heart/daemon/os-cron.js +14 -12
  84. package/dist/heart/daemon/ouro-bot-entry.js +4 -2
  85. package/dist/heart/daemon/ouro-entry.js +3 -1
  86. package/dist/heart/daemon/process-manager.js +375 -33
  87. package/dist/heart/daemon/provider-discovery.js +137 -0
  88. package/dist/heart/daemon/provider-ping-progress.js +83 -0
  89. package/dist/heart/daemon/pulse.js +475 -0
  90. package/dist/heart/daemon/readiness-repair.js +365 -0
  91. package/dist/heart/daemon/run-hooks.js +2 -0
  92. package/dist/heart/daemon/runtime-logging.js +67 -16
  93. package/dist/heart/daemon/runtime-metadata.js +3 -31
  94. package/dist/heart/daemon/safe-mode.js +161 -0
  95. package/dist/heart/daemon/sense-manager.js +353 -38
  96. package/dist/heart/daemon/session-id-resolver.js +131 -0
  97. package/dist/heart/daemon/skill-management-installer.js +94 -0
  98. package/dist/heart/daemon/socket-client.js +158 -11
  99. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  100. package/dist/heart/daemon/startup-tui.js +330 -0
  101. package/dist/heart/daemon/task-scheduler.js +3 -25
  102. package/dist/heart/daemon/terminal-ui.js +499 -0
  103. package/dist/heart/daemon/thoughts.js +162 -17
  104. package/dist/heart/daemon/up-progress.js +366 -0
  105. package/dist/heart/daemon/vault-items.js +56 -0
  106. package/dist/heart/delegation.js +1 -1
  107. package/dist/heart/habits/habit-migration.js +189 -0
  108. package/dist/heart/habits/habit-parser.js +140 -0
  109. package/dist/heart/habits/habit-runtime-state.js +100 -0
  110. package/dist/heart/habits/habit-scheduler.js +372 -0
  111. package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
  112. package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
  113. package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
  114. package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
  115. package/dist/heart/identity.js +200 -51
  116. package/dist/heart/kept-notes.js +357 -0
  117. package/dist/heart/kicks.js +1 -1
  118. package/dist/heart/machine-identity.js +161 -0
  119. package/dist/heart/mail-import-discovery.js +353 -0
  120. package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
  121. package/dist/heart/mailbox/mailbox-http-response.js +7 -0
  122. package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
  123. package/dist/heart/mailbox/mailbox-http-static.js +103 -0
  124. package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
  125. package/dist/heart/mailbox/mailbox-http.js +99 -0
  126. package/dist/heart/mailbox/mailbox-read.js +31 -0
  127. package/dist/heart/mailbox/mailbox-types.js +27 -0
  128. package/dist/heart/mailbox/mailbox-view.js +195 -0
  129. package/dist/heart/mailbox/readers/agent-machine.js +382 -0
  130. package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
  131. package/dist/heart/mailbox/readers/mail.js +362 -0
  132. package/dist/heart/mailbox/readers/runtime-readers.js +651 -0
  133. package/dist/heart/mailbox/readers/sessions.js +232 -0
  134. package/dist/heart/mailbox/readers/shared.js +111 -0
  135. package/dist/heart/mcp/mcp-server.js +683 -0
  136. package/dist/heart/migrate-config.js +100 -0
  137. package/dist/heart/model-capabilities.js +19 -0
  138. package/dist/heart/platform.js +81 -0
  139. package/dist/heart/provider-attempt.js +134 -0
  140. package/dist/heart/provider-binding-resolver.js +255 -0
  141. package/dist/heart/provider-credentials.js +425 -0
  142. package/dist/heart/provider-failover.js +301 -0
  143. package/dist/heart/provider-models.js +81 -0
  144. package/dist/heart/provider-ping.js +262 -0
  145. package/dist/heart/provider-state.js +216 -0
  146. package/dist/heart/provider-visibility.js +188 -0
  147. package/dist/heart/providers/anthropic-token.js +131 -0
  148. package/dist/heart/providers/anthropic.js +139 -52
  149. package/dist/heart/providers/azure.js +97 -13
  150. package/dist/heart/providers/error-classification.js +127 -0
  151. package/dist/heart/providers/github-copilot.js +145 -0
  152. package/dist/heart/providers/minimax-vlm.js +189 -0
  153. package/dist/heart/providers/minimax.js +26 -8
  154. package/dist/heart/providers/openai-codex.js +55 -40
  155. package/dist/heart/runtime-capability-check.js +170 -0
  156. package/dist/heart/runtime-credentials.js +367 -0
  157. package/dist/heart/runtime-cwd.js +87 -0
  158. package/dist/heart/sense-truth.js +11 -4
  159. package/dist/heart/session-activity.js +43 -22
  160. package/dist/heart/session-events.js +1149 -0
  161. package/dist/heart/session-playback-cli-main.js +5 -0
  162. package/dist/heart/session-playback-cli.js +36 -0
  163. package/dist/heart/session-playback.js +231 -0
  164. package/dist/heart/session-stats-cli-main.js +5 -0
  165. package/dist/heart/session-stats.js +182 -0
  166. package/dist/heart/session-transcript.js +243 -0
  167. package/dist/heart/start-of-turn-packet.js +345 -0
  168. package/dist/heart/streaming.js +44 -27
  169. package/dist/heart/sync-classification.js +176 -0
  170. package/dist/heart/sync.js +449 -0
  171. package/dist/heart/target-resolution.js +9 -5
  172. package/dist/heart/tempo.js +93 -0
  173. package/dist/heart/temporal-view.js +41 -0
  174. package/dist/heart/timeouts.js +101 -0
  175. package/dist/heart/tool-activity-callbacks.js +59 -0
  176. package/dist/heart/tool-description.js +139 -0
  177. package/dist/heart/tool-friction.js +55 -0
  178. package/dist/heart/tool-loop.js +200 -0
  179. package/dist/heart/turn-context.js +381 -0
  180. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +6 -5
  181. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  182. package/dist/heart/versioning/ouro-path-installer.js +426 -0
  183. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  184. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  185. package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
  186. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  187. package/dist/mailbox-ui/assets/index-BPr5vNuM.css +1 -0
  188. package/dist/mailbox-ui/assets/index-Cm51CY9W.js +61 -0
  189. package/dist/mailbox-ui/index.html +15 -0
  190. package/dist/mailroom/attention.js +167 -0
  191. package/dist/mailroom/autonomy.js +209 -0
  192. package/dist/mailroom/blob-store.js +674 -0
  193. package/dist/mailroom/body-cache.js +61 -0
  194. package/dist/mailroom/core.js +720 -0
  195. package/dist/mailroom/entry.js +160 -0
  196. package/dist/mailroom/file-store.js +430 -0
  197. package/dist/mailroom/mbox-import.js +383 -0
  198. package/dist/mailroom/outbound.js +380 -0
  199. package/dist/mailroom/policy.js +263 -0
  200. package/dist/mailroom/reader.js +233 -0
  201. package/dist/mailroom/search-cache.js +256 -0
  202. package/dist/mailroom/search-relevance.js +319 -0
  203. package/dist/mailroom/smtp-ingress.js +176 -0
  204. package/dist/mailroom/source-state.js +176 -0
  205. package/dist/mailroom/thread.js +109 -0
  206. package/dist/mailroom/travel-extract.js +89 -0
  207. package/dist/mind/bundle-manifest.js +7 -1
  208. package/dist/mind/context.js +165 -101
  209. package/dist/mind/diary-integrity.js +60 -0
  210. package/dist/mind/{memory.js → diary.js} +62 -75
  211. package/dist/mind/embedding-provider.js +60 -0
  212. package/dist/mind/file-state.js +179 -0
  213. package/dist/mind/friends/channel.js +30 -0
  214. package/dist/mind/friends/resolver.js +54 -2
  215. package/dist/mind/friends/store-file.js +39 -3
  216. package/dist/mind/friends/types.js +2 -2
  217. package/dist/mind/journal-index.js +161 -0
  218. package/dist/mind/note-search.js +268 -0
  219. package/dist/mind/obligation-steering.js +221 -0
  220. package/dist/mind/pending.js +4 -0
  221. package/dist/mind/prompt-refresh.js +3 -2
  222. package/dist/mind/prompt.js +995 -123
  223. package/dist/mind/provenance-trust.js +26 -0
  224. package/dist/mind/scrutiny.js +173 -0
  225. package/dist/nerves/cli-logging.js +7 -1
  226. package/dist/nerves/coverage/audit-rules.js +15 -6
  227. package/dist/nerves/coverage/audit.js +28 -2
  228. package/dist/nerves/coverage/cli.js +1 -1
  229. package/dist/nerves/coverage/contract.js +5 -5
  230. package/dist/nerves/coverage/file-completeness.js +139 -5
  231. package/dist/nerves/coverage/run-artifacts.js +1 -1
  232. package/dist/nerves/event-buffer.js +111 -0
  233. package/dist/nerves/index.js +224 -4
  234. package/dist/nerves/observation.js +20 -0
  235. package/dist/nerves/redact.js +79 -0
  236. package/dist/nerves/review/cli-main.js +5 -0
  237. package/dist/nerves/review/cli.js +156 -0
  238. package/dist/nerves/review/core.js +152 -0
  239. package/dist/nerves/runtime.js +5 -1
  240. package/dist/repertoire/ado-client.js +15 -56
  241. package/dist/repertoire/ado-semantic.js +11 -10
  242. package/dist/repertoire/api-client.js +97 -0
  243. package/dist/repertoire/bitwarden-store.js +816 -0
  244. package/dist/repertoire/bundle-templates.js +72 -0
  245. package/dist/repertoire/bw-installer.js +180 -0
  246. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  247. package/dist/repertoire/coding/context-pack.js +330 -0
  248. package/dist/repertoire/coding/feedback.js +197 -30
  249. package/dist/repertoire/coding/manager.js +158 -9
  250. package/dist/repertoire/coding/spawner.js +55 -9
  251. package/dist/repertoire/coding/tools.js +170 -7
  252. package/dist/repertoire/commerce-errors.js +109 -0
  253. package/dist/repertoire/commerce-self-test.js +156 -0
  254. package/dist/repertoire/credential-access.js +111 -0
  255. package/dist/repertoire/duffel-client.js +185 -0
  256. package/dist/repertoire/github-client.js +14 -55
  257. package/dist/repertoire/graph-client.js +11 -52
  258. package/dist/repertoire/guardrails.js +396 -0
  259. package/dist/repertoire/mcp-client.js +295 -0
  260. package/dist/repertoire/mcp-manager.js +362 -0
  261. package/dist/repertoire/mcp-tools.js +63 -0
  262. package/dist/repertoire/shell-sessions.js +133 -0
  263. package/dist/repertoire/skills.js +15 -24
  264. package/dist/repertoire/stripe-client.js +131 -0
  265. package/dist/repertoire/tasks/board.js +31 -5
  266. package/dist/repertoire/tasks/fix.js +182 -0
  267. package/dist/repertoire/tasks/index.js +16 -4
  268. package/dist/repertoire/tasks/lifecycle.js +2 -2
  269. package/dist/repertoire/tasks/parser.js +3 -2
  270. package/dist/repertoire/tasks/scanner.js +194 -37
  271. package/dist/repertoire/tasks/transitions.js +16 -78
  272. package/dist/repertoire/tool-results.js +29 -0
  273. package/dist/repertoire/tools-attachments.js +317 -0
  274. package/dist/repertoire/tools-base.js +47 -1075
  275. package/dist/repertoire/tools-bluebubbles.js +1 -0
  276. package/dist/repertoire/tools-bridge.js +142 -0
  277. package/dist/repertoire/tools-bundle.js +984 -0
  278. package/dist/repertoire/tools-config.js +185 -0
  279. package/dist/repertoire/tools-continuity.js +248 -0
  280. package/dist/repertoire/tools-credential.js +381 -0
  281. package/dist/repertoire/tools-files.js +342 -0
  282. package/dist/repertoire/tools-flight.js +224 -0
  283. package/dist/repertoire/tools-flow.js +119 -0
  284. package/dist/repertoire/tools-github.js +1 -7
  285. package/dist/repertoire/tools-mail.js +1857 -0
  286. package/dist/repertoire/tools-notes.js +421 -0
  287. package/dist/repertoire/tools-session.js +750 -0
  288. package/dist/repertoire/tools-shell.js +120 -0
  289. package/dist/repertoire/tools-stripe.js +180 -0
  290. package/dist/repertoire/tools-surface.js +243 -0
  291. package/dist/repertoire/tools-teams.js +9 -39
  292. package/dist/repertoire/tools-travel.js +125 -0
  293. package/dist/repertoire/tools-trip.js +604 -0
  294. package/dist/repertoire/tools-user-profile.js +144 -0
  295. package/dist/repertoire/tools-vault.js +40 -0
  296. package/dist/repertoire/tools.js +108 -100
  297. package/dist/repertoire/travel-api-client.js +360 -0
  298. package/dist/repertoire/user-profile.js +131 -0
  299. package/dist/repertoire/vault-setup.js +246 -0
  300. package/dist/repertoire/vault-unlock.js +561 -0
  301. package/dist/scripts/claude-code-hook.js +41 -0
  302. package/dist/scripts/claude-code-stop-hook.js +47 -0
  303. package/dist/senses/attention-queue.js +116 -0
  304. package/dist/senses/bluebubbles/active-turns.js +216 -0
  305. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  306. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  307. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
  308. package/dist/senses/bluebubbles/entry.js +77 -0
  309. package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
  310. package/dist/senses/bluebubbles/index.js +2305 -0
  311. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  312. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
  313. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
  314. package/dist/senses/bluebubbles/processed-log.js +133 -0
  315. package/dist/senses/bluebubbles/replay.js +137 -0
  316. package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
  317. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  318. package/dist/senses/cli/bracketed-paste.js +82 -0
  319. package/dist/senses/cli/image-paste.js +287 -0
  320. package/dist/senses/cli/image-ref-navigation.js +75 -0
  321. package/dist/senses/cli/ink-app.js +156 -0
  322. package/dist/senses/cli/inline-diff.js +64 -0
  323. package/dist/senses/cli/input-keys.js +174 -0
  324. package/dist/senses/cli/kill-ring.js +86 -0
  325. package/dist/senses/cli/message-list.js +51 -0
  326. package/dist/senses/cli/ouro-tui.js +607 -0
  327. package/dist/senses/cli/spinner-imperative.js +135 -0
  328. package/dist/senses/cli/spinner.js +101 -0
  329. package/dist/senses/cli/status-line.js +60 -0
  330. package/dist/senses/cli/streaming-markdown.js +526 -0
  331. package/dist/senses/cli/tool-display.js +85 -0
  332. package/dist/senses/cli/tool-render.js +85 -0
  333. package/dist/senses/cli/tui-store.js +240 -0
  334. package/dist/senses/cli/virtual-list.js +35 -0
  335. package/dist/senses/cli-entry.js +60 -8
  336. package/dist/senses/cli-layout.js +187 -0
  337. package/dist/senses/cli.js +520 -209
  338. package/dist/senses/commands.js +66 -3
  339. package/dist/senses/habit-turn-message.js +108 -0
  340. package/dist/senses/inner-dialog-worker.js +175 -21
  341. package/dist/senses/inner-dialog.js +330 -27
  342. package/dist/senses/mail-entry.js +66 -0
  343. package/dist/senses/mail.js +379 -0
  344. package/dist/senses/pipeline.js +569 -182
  345. package/dist/senses/proactive-content-guard.js +51 -0
  346. package/dist/senses/shared-turn.js +248 -0
  347. package/dist/senses/surface-tool.js +68 -0
  348. package/dist/senses/teams-entry.js +60 -8
  349. package/dist/senses/teams.js +387 -98
  350. package/dist/senses/trust-gate.js +100 -5
  351. package/dist/trips/core.js +138 -0
  352. package/dist/trips/store.js +146 -0
  353. package/package.json +38 -7
  354. package/skills/agent-commerce.md +106 -0
  355. package/skills/browser-navigation.md +117 -0
  356. package/skills/commerce-setup-guide.md +116 -0
  357. package/skills/commerce-setup.md +84 -0
  358. package/skills/configure-dev-tools.md +101 -0
  359. package/skills/travel-planning.md +138 -0
  360. package/dist/heart/daemon/ouro-path-installer.js +0 -178
  361. package/dist/heart/daemon/subagent-installer.js +0 -166
  362. package/dist/heart/session-recall.js +0 -116
  363. package/dist/mind/associative-recall.js +0 -209
  364. package/dist/senses/bluebubbles-entry.js +0 -13
  365. package/dist/senses/bluebubbles.js +0 -1177
  366. package/dist/senses/debug-activity.js +0 -148
  367. package/subagents/README.md +0 -86
  368. package/subagents/work-doer.md +0 -237
  369. package/subagents/work-merger.md +0 -618
  370. package/subagents/work-planner.md +0 -390
  371. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  372. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  373. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  374. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  375. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  376. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  377. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  378. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  379. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  380. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  381. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  382. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  383. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  384. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  385. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  386. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
@@ -0,0 +1,665 @@
1
+ "use strict";
2
+ /**
3
+ * CLI default dependency wiring.
4
+ *
5
+ * Creates the production OuroCliDeps with real filesystem, socket, and
6
+ * process bindings. Tests inject mocks for all of these.
7
+ */
8
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
9
+ if (k2 === undefined) k2 = k;
10
+ var desc = Object.getOwnPropertyDescriptor(m, k);
11
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
12
+ desc = { enumerable: true, get: function() { return m[k]; } };
13
+ }
14
+ Object.defineProperty(o, k2, desc);
15
+ }) : (function(o, m, k, k2) {
16
+ if (k2 === undefined) k2 = k;
17
+ o[k2] = m[k];
18
+ }));
19
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
20
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
21
+ }) : function(o, v) {
22
+ o["default"] = v;
23
+ });
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.defaultStartDaemonProcess = defaultStartDaemonProcess;
43
+ exports.readFirstBundleMetaVersion = readFirstBundleMetaVersion;
44
+ exports.defaultListDiscoveredAgents = defaultListDiscoveredAgents;
45
+ exports.defaultRunSerpentGuide = defaultRunSerpentGuide;
46
+ exports.createDefaultOuroCliDeps = createDefaultOuroCliDeps;
47
+ const child_process_1 = require("child_process");
48
+ const fs = __importStar(require("fs"));
49
+ const os = __importStar(require("os"));
50
+ const path = __importStar(require("path"));
51
+ const identity_1 = require("../identity");
52
+ const runtime_1 = require("../../nerves/runtime");
53
+ const ouro_path_installer_1 = require("../versioning/ouro-path-installer");
54
+ const ouro_uti_1 = require("../versioning/ouro-uti");
55
+ const ouro_version_manager_1 = require("../versioning/ouro-version-manager");
56
+ const update_checker_1 = require("../versioning/update-checker");
57
+ const skill_management_installer_1 = require("./skill-management-installer");
58
+ const hatch_flow_1 = require("../hatch/hatch-flow");
59
+ const specialist_orchestrator_1 = require("../hatch/specialist-orchestrator");
60
+ const specialist_prompt_1 = require("../hatch/specialist-prompt");
61
+ const specialist_tools_1 = require("../hatch/specialist-tools");
62
+ const runtime_mode_1 = require("./runtime-mode");
63
+ const agent_discovery_1 = require("./agent-discovery");
64
+ const bundle_manifest_1 = require("../../mind/bundle-manifest");
65
+ const ouro_bot_global_installer_1 = require("../versioning/ouro-bot-global-installer");
66
+ const logs_prune_1 = require("./logs-prune");
67
+ const daemon_health_1 = require("./daemon-health");
68
+ const log_tailer_1 = require("./log-tailer");
69
+ const launchd_1 = require("./launchd");
70
+ const socket_client_1 = require("./socket-client");
71
+ const session_activity_1 = require("../session-activity");
72
+ const auth_flow_1 = require("../auth/auth-flow");
73
+ const provider_models_1 = require("../provider-models");
74
+ const cli_parse_1 = require("./cli-parse");
75
+ const provider_discovery_1 = require("./provider-discovery");
76
+ const provider_credentials_1 = require("../provider-credentials");
77
+ // ── Default implementations ──
78
+ function defaultStartDaemonProcess(socketPath) {
79
+ const entry = path.join((0, identity_1.getRepoRoot)(), "dist", "heart", "daemon", "daemon-entry.js");
80
+ // Redirect stdio to /dev/null via file descriptors — using 'ignore' causes EPIPE
81
+ // when the daemon's logging system writes to stderr after the parent exits.
82
+ const outFd = fs.openSync(os.devNull, "w");
83
+ const errFd = fs.openSync(os.devNull, "w");
84
+ const child = (0, child_process_1.spawn)(process.execPath, [entry, "--socket", socketPath], {
85
+ detached: true,
86
+ stdio: ["ignore", outFd, errFd],
87
+ });
88
+ child.unref();
89
+ // Don't close fds — the child process needs them. They'll be cleaned up when the parent exits.
90
+ return Promise.resolve({ pid: child.pid ?? null });
91
+ }
92
+ function defaultWriteStdout(text) {
93
+ process.stdout.write(text.endsWith("\n") ? text : `${text}\n`);
94
+ }
95
+ /* v8 ignore start -- thin terminal adapter around process stdout @preserve */
96
+ function defaultWriteRaw(text) {
97
+ process.stdout.write(text);
98
+ }
99
+ /* v8 ignore stop */
100
+ function resolveDaemonBootEntryPath(homeDir) {
101
+ const repoRoot = (0, identity_1.getRepoRoot)();
102
+ const versionManagerRootMarker = `${path.sep}.ouro-cli${path.sep}versions${path.sep}`;
103
+ if ((0, runtime_mode_1.detectRuntimeMode)(repoRoot) === "production" && repoRoot.includes(versionManagerRootMarker)) {
104
+ return path.join((0, ouro_version_manager_1.getOuroCliHome)(homeDir), "CurrentVersion", "node_modules", "@ouro.bot", "cli", "dist", "heart", "daemon", "daemon-entry.js");
105
+ }
106
+ return path.join(repoRoot, "dist", "heart", "daemon", "daemon-entry.js");
107
+ }
108
+ /**
109
+ * Read the runtimeVersion from the first .ouro bundle's bundle-meta.json.
110
+ * Returns undefined if none found or unreadable.
111
+ */
112
+ function readFirstBundleMetaVersion(bundlesRoot) {
113
+ try {
114
+ if (!fs.existsSync(bundlesRoot))
115
+ return undefined;
116
+ const entries = fs.readdirSync(bundlesRoot, { withFileTypes: true });
117
+ for (const entry of entries) {
118
+ /* v8 ignore next -- skip non-.ouro dirs: tested via version-detect tests @preserve */
119
+ if (!entry.isDirectory() || !entry.name.endsWith(".ouro"))
120
+ continue;
121
+ const metaPath = path.join(bundlesRoot, entry.name, "bundle-meta.json");
122
+ if (!fs.existsSync(metaPath))
123
+ continue;
124
+ const raw = fs.readFileSync(metaPath, "utf-8");
125
+ const meta = JSON.parse(raw);
126
+ if (meta.runtimeVersion)
127
+ return meta.runtimeVersion;
128
+ }
129
+ }
130
+ catch {
131
+ // Best effort — return undefined on any error
132
+ }
133
+ return undefined;
134
+ }
135
+ function defaultCleanupStaleSocket(socketPath) {
136
+ if (fs.existsSync(socketPath)) {
137
+ fs.unlinkSync(socketPath);
138
+ }
139
+ }
140
+ function defaultReadHealthUpdatedAt(healthPath) {
141
+ try {
142
+ return fs.statSync(healthPath).mtimeMs;
143
+ }
144
+ catch {
145
+ return null;
146
+ }
147
+ }
148
+ function defaultReadRecentDaemonLogLines(lines = 10) {
149
+ const files = (0, log_tailer_1.discoverLogFiles)({});
150
+ const recentLines = [];
151
+ for (const file of files) {
152
+ recentLines.push(...(0, log_tailer_1.readLastLines)(file, lines, fs.readFileSync));
153
+ }
154
+ return recentLines.slice(-lines).map((line) => (0, log_tailer_1.formatLogLine)(line));
155
+ }
156
+ /* v8 ignore start -- CLI npm registry fetch wrapper: integration code @preserve */
157
+ async function defaultFetchCliRegistryJson(timeoutMs) {
158
+ const controller = new AbortController();
159
+ const timeoutId = setTimeout(() => {
160
+ controller.abort();
161
+ }, timeoutMs);
162
+ try {
163
+ const res = await fetch("https://registry.npmjs.org/@ouro.bot/cli", {
164
+ signal: controller.signal,
165
+ });
166
+ return res.json();
167
+ }
168
+ catch (error) {
169
+ if (error instanceof Error && error.name === "AbortError") {
170
+ throw new Error(`update check timed out after ${Math.max(1, Math.round(timeoutMs / 1000))}s`);
171
+ }
172
+ throw error;
173
+ }
174
+ finally {
175
+ clearTimeout(timeoutId);
176
+ }
177
+ }
178
+ /* v8 ignore stop */
179
+ function defaultSleep(ms) {
180
+ return new Promise((resolve) => setTimeout(resolve, ms));
181
+ }
182
+ function defaultSpawnBackgroundCli(argv) {
183
+ const child = (0, child_process_1.spawn)(process.execPath, argv, {
184
+ detached: true,
185
+ stdio: "ignore",
186
+ });
187
+ child.unref();
188
+ return Promise.resolve({ pid: child.pid ?? null });
189
+ }
190
+ function defaultFallbackPendingMessage(command) {
191
+ const inboxDir = path.join((0, identity_1.getAgentBundlesRoot)(), `${command.to}.ouro`, "inbox");
192
+ const pendingPath = path.join(inboxDir, "pending.jsonl");
193
+ const queuedAt = new Date().toISOString();
194
+ const payload = {
195
+ from: command.from,
196
+ to: command.to,
197
+ content: command.content,
198
+ priority: command.priority ?? "normal",
199
+ sessionId: command.sessionId,
200
+ taskRef: command.taskRef,
201
+ queuedAt,
202
+ };
203
+ fs.mkdirSync(inboxDir, { recursive: true });
204
+ fs.appendFileSync(pendingPath, `${JSON.stringify(payload)}\n`, "utf-8");
205
+ (0, runtime_1.emitNervesEvent)({
206
+ level: "warn",
207
+ component: "daemon",
208
+ event: "daemon.message_fallback_queued",
209
+ message: "queued message to pending fallback file",
210
+ meta: {
211
+ to: command.to,
212
+ path: pendingPath,
213
+ sessionId: command.sessionId ?? null,
214
+ taskRef: command.taskRef ?? null,
215
+ },
216
+ });
217
+ return pendingPath;
218
+ }
219
+ function defaultEnsureDaemonBootPersistence(socketPath) {
220
+ if (process.platform !== "darwin") {
221
+ return;
222
+ }
223
+ const homeDir = os.homedir();
224
+ const writeDeps = {
225
+ writeFile: (filePath, content) => fs.writeFileSync(filePath, content, "utf-8"),
226
+ mkdirp: (dir) => fs.mkdirSync(dir, { recursive: true }),
227
+ homeDir,
228
+ };
229
+ const entryPath = resolveDaemonBootEntryPath(homeDir);
230
+ /* v8 ignore next -- covered via mock in daemon-cli-defaults.test.ts; v8 on CI attributes the real fs.existsSync branch to the non-mock load @preserve */
231
+ if (!fs.existsSync(entryPath)) {
232
+ (0, runtime_1.emitNervesEvent)({
233
+ level: "warn",
234
+ component: "daemon",
235
+ event: "daemon.entry_path_missing",
236
+ message: "entryPath does not exist on disk — plist may point to a stale location. Run 'ouro daemon install' from the correct location.",
237
+ meta: { entryPath },
238
+ });
239
+ }
240
+ const logDir = (0, identity_1.getAgentDaemonLogsDir)();
241
+ // Write plist only — do NOT launchctl bootstrap.
242
+ // The daemon is already running (started by ouro up). Bootstrapping would
243
+ // start a SECOND daemon via launchd's RunAtLoad, causing a race where
244
+ // killOrphanProcesses kills the first daemon and both end up dead.
245
+ // The plist on disk is sufficient: launchd picks it up on login.
246
+ (0, launchd_1.writeLaunchAgentPlist)(writeDeps, {
247
+ nodePath: process.execPath,
248
+ entryPath,
249
+ socketPath,
250
+ logDir,
251
+ envPath: process.env.PATH,
252
+ });
253
+ }
254
+ function defaultPrepareDaemonRuntimeReplacement() {
255
+ if (process.platform !== "darwin") {
256
+ return;
257
+ }
258
+ (0, launchd_1.bootoutLaunchAgentByLabel)({
259
+ exec: (cmd) => { (0, child_process_1.execSync)(cmd, { stdio: "ignore" }); },
260
+ userUid: process.getuid?.() ?? 0,
261
+ });
262
+ // launchctl bootout may return before the old daemon's SIGTERM cleanup has
263
+ // finished unlinking its Unix socket. Give that cleanup a short chance to
264
+ // settle before the replacement daemon binds the same socket path.
265
+ (0, child_process_1.execSync)("/bin/sleep 1", { stdio: "ignore" });
266
+ }
267
+ async function defaultPromptInput(question) {
268
+ const readline = await Promise.resolve().then(() => __importStar(require("readline/promises")));
269
+ const rl = readline.createInterface({
270
+ input: process.stdin,
271
+ output: process.stdout,
272
+ });
273
+ try {
274
+ const response = await rl.question(question);
275
+ return response.trim();
276
+ }
277
+ finally {
278
+ rl.close();
279
+ }
280
+ }
281
+ async function defaultPromptSecret(question) {
282
+ if (process.stdin.isTTY !== true || process.stdout.isTTY !== true) {
283
+ throw new Error("vault unlock secret entry requires an interactive terminal so the secret can be hidden. Re-run this command in a terminal and enter the human-chosen secret when prompted.");
284
+ }
285
+ const readline = await Promise.resolve().then(() => __importStar(require("readline")));
286
+ const rl = readline.createInterface({
287
+ input: process.stdin,
288
+ output: process.stdout,
289
+ terminal: true,
290
+ });
291
+ const mutableRl = rl;
292
+ const originalWriteToOutput = mutableRl._writeToOutput;
293
+ let muted = false;
294
+ if (originalWriteToOutput) {
295
+ mutableRl._writeToOutput = (stringToWrite) => {
296
+ if (!muted) {
297
+ originalWriteToOutput.call(rl, stringToWrite);
298
+ }
299
+ };
300
+ }
301
+ try {
302
+ const response = await new Promise((resolve) => {
303
+ rl.question(question, (answer) => {
304
+ process.stdout.write("\n");
305
+ resolve(answer);
306
+ });
307
+ muted = true;
308
+ });
309
+ return response.trim();
310
+ }
311
+ finally {
312
+ if (originalWriteToOutput) {
313
+ mutableRl._writeToOutput = originalWriteToOutput;
314
+ }
315
+ rl.close();
316
+ }
317
+ }
318
+ function defaultListDiscoveredAgents() {
319
+ return (0, agent_discovery_1.listEnabledBundleAgents)({
320
+ bundlesRoot: (0, identity_1.getAgentBundlesRoot)(),
321
+ readdirSync: fs.readdirSync,
322
+ readFileSync: fs.readFileSync,
323
+ });
324
+ }
325
+ // ── Serpent guide (interactive hatch) ──
326
+ /* v8 ignore start -- integration: interactive terminal specialist session @preserve */
327
+ async function defaultRunSerpentGuide() {
328
+ const { runCliSession } = await Promise.resolve().then(() => __importStar(require("../../senses/cli")));
329
+ const { setAgentName, setAgentConfigOverride } = await Promise.resolve().then(() => __importStar(require("../identity")));
330
+ const readlinePromises = await Promise.resolve().then(() => __importStar(require("readline/promises")));
331
+ const crypto = await Promise.resolve().then(() => __importStar(require("crypto")));
332
+ // Phase 1: cold CLI — collect provider/credentials with a simple readline
333
+ const coldRl = readlinePromises.createInterface({ input: process.stdin, output: process.stdout });
334
+ const coldPrompt = async (q) => {
335
+ const answer = await coldRl.question(q);
336
+ return answer.trim();
337
+ };
338
+ let providerRaw;
339
+ let credentials = {};
340
+ let providerConfig = {};
341
+ let selectedCredentialPayload = {};
342
+ const tempDir = path.join(os.tmpdir(), `ouro-hatch-${crypto.randomUUID()}`);
343
+ try {
344
+ const discovered = [];
345
+ const existingBundles = (0, specialist_orchestrator_1.listExistingBundles)((0, identity_1.getAgentBundlesRoot)());
346
+ const existingBundleCount = existingBundles.length;
347
+ const hatchVerb = existingBundleCount > 0 ? "let's hatch a new agent." : "let's hatch your first agent.";
348
+ // Default models per provider (used when entering new credentials)
349
+ const defaultModels = provider_models_1.DEFAULT_PROVIDER_MODELS;
350
+ const { pingProvider } = await Promise.resolve().then(() => __importStar(require("../provider-ping")));
351
+ const installedAgentCreds = await (0, provider_discovery_1.discoverInstalledAgentCredentials)(existingBundles);
352
+ for (const cred of installedAgentCreds) {
353
+ discovered.push({
354
+ ...cred,
355
+ providerConfig: { model: defaultModels[cred.provider], ...cred.providerConfig },
356
+ });
357
+ }
358
+ // Scan environment variables for API keys using the shared helper
359
+ const envCreds = (0, provider_discovery_1.scanEnvVarCredentials)(process.env);
360
+ const envDiscovered = [];
361
+ for (const cred of envCreds) {
362
+ // Enrich with default model and first matching env var name (for display)
363
+ const desc = identity_1.PROVIDER_CREDENTIALS[cred.provider];
364
+ const firstEnvVar = Object.entries(desc.envVars).find(([envVar]) => process.env[envVar])?.[0] ?? "";
365
+ const provCfg = { model: defaultModels[cred.provider], ...cred.providerConfig };
366
+ if (cred.provider === "azure" && cred.credentials.deployment)
367
+ provCfg.deployment = cred.credentials.deployment;
368
+ const enriched = { ...cred, providerConfig: provCfg };
369
+ envDiscovered.push({ ...enriched, envVar: firstEnvVar });
370
+ discovered.push(enriched);
371
+ }
372
+ let welcomed = false;
373
+ while (true) {
374
+ if (!welcomed) {
375
+ process.stdout.write(`\n\ud83d\udc0d welcome to ouroboros! ${hatchVerb}\n`);
376
+ welcomed = true;
377
+ }
378
+ if (discovered.length > 0) {
379
+ process.stdout.write("i found existing API credentials:\n\n");
380
+ const credentialOptions = discovered;
381
+ for (let i = 0; i < credentialOptions.length; i++) {
382
+ const model = credentialOptions[i].providerConfig.model || credentialOptions[i].providerConfig.deployment || "";
383
+ const modelLabel = model ? `, ${model}` : "";
384
+ const envMatch = envDiscovered.find((e) => e.provider === credentialOptions[i].provider && credentialOptions[i].agentName === "env");
385
+ const sourceLabel = (0, provider_discovery_1.describeDiscoveredCredentialSource)(credentialOptions[i], envMatch?.envVar);
386
+ process.stdout.write(` ${i + 1}. ${credentialOptions[i].provider}${modelLabel} (${sourceLabel})\n`);
387
+ }
388
+ process.stdout.write("\n");
389
+ const choice = await coldPrompt("use one of these? enter number, or 'new' for a different key, or 'q' to cancel: ");
390
+ if (["q", "quit", "cancel"].includes(choice.toLowerCase())) {
391
+ coldRl.close();
392
+ return null;
393
+ }
394
+ const idx = parseInt(choice, 10) - 1;
395
+ if (idx >= 0 && idx < credentialOptions.length) {
396
+ providerRaw = credentialOptions[idx].provider;
397
+ credentials = credentialOptions[idx].credentials;
398
+ providerConfig = credentialOptions[idx].providerConfig;
399
+ }
400
+ else {
401
+ const pRaw = await coldPrompt("provider (anthropic/azure/minimax/openai-codex/github-copilot): ");
402
+ if (!(0, cli_parse_1.isAgentProvider)(pRaw)) {
403
+ process.stdout.write("unknown provider. run `ouro hatch` to try again.\n");
404
+ coldRl.close();
405
+ return null;
406
+ }
407
+ providerRaw = pRaw;
408
+ providerConfig = { model: defaultModels[providerRaw] };
409
+ credentials = await (0, auth_flow_1.collectRuntimeAuthCredentials)({ agentName: "SerpentGuide", provider: providerRaw, promptInput: coldPrompt }, {});
410
+ }
411
+ }
412
+ else {
413
+ process.stdout.write("i need an API key to power our conversation.\n\n");
414
+ const pRaw = await coldPrompt("provider (anthropic/azure/minimax/openai-codex/github-copilot): ");
415
+ if (!(0, cli_parse_1.isAgentProvider)(pRaw)) {
416
+ process.stdout.write("unknown provider. run `ouro hatch` to try again.\n");
417
+ coldRl.close();
418
+ return null;
419
+ }
420
+ providerRaw = pRaw;
421
+ providerConfig = { model: defaultModels[providerRaw] };
422
+ credentials = await (0, auth_flow_1.collectRuntimeAuthCredentials)({ agentName: "SerpentGuide", provider: providerRaw, promptInput: coldPrompt }, {});
423
+ }
424
+ selectedCredentialPayload = { ...providerConfig, ...credentials };
425
+ const pingResult = await pingProvider(providerRaw, selectedCredentialPayload);
426
+ if (pingResult.ok) {
427
+ break;
428
+ }
429
+ process.stdout.write(`credentials didn't work (${pingResult.message}). `);
430
+ if (discovered.length > 0) {
431
+ process.stdout.write("choose another saved credential or enter 'new'.\n\n");
432
+ }
433
+ else {
434
+ process.stdout.write("let's try again.\n\n");
435
+ }
436
+ }
437
+ coldRl.close();
438
+ process.stdout.write("\n");
439
+ const split = (0, provider_credentials_1.splitProviderCredentialFields)(providerRaw, selectedCredentialPayload);
440
+ (0, provider_credentials_1.cacheProviderCredentialRecords)("SerpentGuide", [
441
+ (0, provider_credentials_1.createProviderCredentialRecord)({
442
+ provider: providerRaw,
443
+ credentials: split.credentials,
444
+ config: split.config,
445
+ provenance: { source: "manual" },
446
+ }),
447
+ ]);
448
+ // Phase 2: configure runtime for serpent guide
449
+ const bundleSourceDir = path.resolve(__dirname, "..", "..", "..", "SerpentGuide.ouro");
450
+ const bundlesRoot = (0, identity_1.getAgentBundlesRoot)();
451
+ // Suppress non-critical log noise during hatch.
452
+ const { setRuntimeLogger } = await Promise.resolve().then(() => __importStar(require("../../nerves/runtime")));
453
+ const { createLogger } = await Promise.resolve().then(() => __importStar(require("../../nerves")));
454
+ setRuntimeLogger(createLogger({ level: "error" }));
455
+ // Configure runtime: set agent identity + config override so runAgent
456
+ // doesn't try to read from ~/AgentBundles/SerpentGuide.ouro/. (As of
457
+ // Layer 3, SerpentGuide identities live in-repo only — the
458
+ // `~/AgentBundles/SerpentGuide.ouro/psyche/identities` override path
459
+ // was removed. The override path is no longer read or honored.)
460
+ setAgentName("SerpentGuide");
461
+ // Build specialist system prompt
462
+ const soulText = (0, specialist_orchestrator_1.loadSoulText)(bundleSourceDir);
463
+ const identitiesDir = path.join(bundleSourceDir, "psyche", "identities");
464
+ const identity = (0, specialist_orchestrator_1.pickRandomIdentity)(identitiesDir);
465
+ // Load identity-specific spinner phrases (falls back to DEFAULT_AGENT_PHRASES)
466
+ const { loadIdentityPhrases } = await Promise.resolve().then(() => __importStar(require("../hatch/specialist-orchestrator")));
467
+ const phrases = loadIdentityPhrases(bundleSourceDir, identity.fileName);
468
+ const resolvedModel = providerConfig.model || providerConfig.deployment || "";
469
+ setAgentConfigOverride({
470
+ version: 2,
471
+ enabled: true,
472
+ provider: providerRaw,
473
+ humanFacing: { provider: providerRaw, model: resolvedModel },
474
+ agentFacing: { provider: providerRaw, model: resolvedModel },
475
+ phrases,
476
+ });
477
+ const systemPrompt = (0, specialist_prompt_1.buildSpecialistSystemPrompt)(soulText, identity.content, existingBundles, {
478
+ tempDir,
479
+ provider: providerRaw,
480
+ model: providerConfig.model ?? "",
481
+ });
482
+ // Build specialist tools
483
+ const specialistTools = (0, specialist_tools_1.getSpecialistTools)();
484
+ const specialistExecTool = (0, specialist_tools_1.createSpecialistExecTool)({
485
+ tempDir,
486
+ credentials: selectedCredentialPayload,
487
+ provider: providerRaw,
488
+ bundlesRoot,
489
+ animationWriter: (text) => process.stdout.write(text),
490
+ promptSecret: defaultPromptSecret,
491
+ });
492
+ // Run the serpent guide session via runCliSession
493
+ const result = await runCliSession({
494
+ agentName: "SerpentGuide",
495
+ tools: specialistTools,
496
+ execTool: specialistExecTool,
497
+ exitOnToolCall: "complete_adoption",
498
+ autoFirstTurn: true,
499
+ banner: false,
500
+ disableCommands: true,
501
+ skipSystemPromptRefresh: true,
502
+ messages: [
503
+ { role: "system", content: systemPrompt },
504
+ { role: "user", content: "hi" },
505
+ ],
506
+ });
507
+ if (result.exitReason === "tool_exit" && result.toolResult) {
508
+ const parsed = typeof result.toolResult === "string" ? JSON.parse(result.toolResult) : result.toolResult;
509
+ if (parsed.success && parsed.agentName) {
510
+ return parsed.agentName;
511
+ }
512
+ }
513
+ return null;
514
+ }
515
+ catch (err) {
516
+ process.stderr.write(`\nouro hatch error: ${err instanceof Error ? err.stack ?? err.message : String(err)}\n`);
517
+ coldRl.close();
518
+ return null;
519
+ }
520
+ finally {
521
+ // Clear specialist config/identity so the hatched agent gets its own
522
+ setAgentConfigOverride(null);
523
+ const { resetProviderRuntime } = await Promise.resolve().then(() => __importStar(require("../core")));
524
+ resetProviderRuntime();
525
+ const { resetConfigCache } = await Promise.resolve().then(() => __importStar(require("../config")));
526
+ resetConfigCache();
527
+ // Restore default logging
528
+ const { setRuntimeLogger: restoreLogger } = await Promise.resolve().then(() => __importStar(require("../../nerves/runtime")));
529
+ restoreLogger(null);
530
+ // Clean up temp dir if it still exists
531
+ try {
532
+ if (fs.existsSync(tempDir)) {
533
+ fs.rmSync(tempDir, { recursive: true, force: true });
534
+ }
535
+ }
536
+ catch {
537
+ // Best effort cleanup
538
+ }
539
+ }
540
+ }
541
+ /* v8 ignore stop */
542
+ // ── Factory ──
543
+ function createDefaultOuroCliDeps(socketPath = socket_client_1.DEFAULT_DAEMON_SOCKET_PATH) {
544
+ return {
545
+ socketPath,
546
+ sendCommand: socket_client_1.sendDaemonCommand,
547
+ startDaemonProcess: defaultStartDaemonProcess,
548
+ writeStdout: defaultWriteStdout,
549
+ setExitCode: (code) => {
550
+ const current = typeof process.exitCode === "number" ? process.exitCode : 0;
551
+ process.exitCode = Math.max(current, code);
552
+ },
553
+ writeRaw: defaultWriteRaw,
554
+ isTTY: process.stdout.isTTY === true,
555
+ checkSocketAlive: socket_client_1.checkDaemonSocketAlive,
556
+ cleanupStaleSocket: defaultCleanupStaleSocket,
557
+ fallbackPendingMessage: defaultFallbackPendingMessage,
558
+ tailLogs: (options) => (0, log_tailer_1.tailLogs)(options),
559
+ healthFilePath: (0, daemon_health_1.getDefaultHealthPath)(),
560
+ readHealthState: daemon_health_1.readHealth,
561
+ readHealthUpdatedAt: defaultReadHealthUpdatedAt,
562
+ readRecentDaemonLogLines: defaultReadRecentDaemonLogLines,
563
+ sleep: defaultSleep,
564
+ spawnBackgroundCli: defaultSpawnBackgroundCli,
565
+ now: () => Date.now(),
566
+ updateCheckTimeoutMs: update_checker_1.CLI_UPDATE_CHECK_TIMEOUT_MS,
567
+ startupPollIntervalMs: 250,
568
+ startupStabilityWindowMs: 1_500,
569
+ startupTimeoutMs: 60_000,
570
+ startupRetryLimit: 1,
571
+ listDiscoveredAgents: defaultListDiscoveredAgents,
572
+ runHatchFlow: hatch_flow_1.runHatchFlow,
573
+ promptInput: defaultPromptInput,
574
+ promptSecret: defaultPromptSecret,
575
+ runSerpentGuide: defaultRunSerpentGuide,
576
+ runAuthFlow: auth_flow_1.runRuntimeAuthFlow,
577
+ registerOuroBundleType: ouro_uti_1.registerOuroBundleUti,
578
+ installOuroCommand: ouro_path_installer_1.installOuroCommand,
579
+ /* v8 ignore start -- self-healing: ensures active symlink matches running runtime version @preserve */
580
+ ensureCurrentVersionInstalled: () => {
581
+ const linkedVersion = (0, ouro_version_manager_1.getCurrentVersion)({});
582
+ const version = (0, bundle_manifest_1.getPackageVersion)();
583
+ if (linkedVersion === version)
584
+ return;
585
+ (0, ouro_version_manager_1.ensureLayout)({});
586
+ const cliHome = (0, ouro_version_manager_1.getOuroCliHome)();
587
+ const versionEntry = path.join(cliHome, "versions", version, "node_modules", "@ouro.bot", "cli", "dist", "heart", "daemon", "ouro-entry.js");
588
+ if (!fs.existsSync(versionEntry)) {
589
+ (0, ouro_version_manager_1.installVersion)(version, {});
590
+ }
591
+ (0, ouro_version_manager_1.activateVersion)(version, {});
592
+ // Self-prune: every successful version activation cleans up old
593
+ // versions outside the retention window. Without this, every CLI
594
+ // version ever installed accumulates indefinitely under
595
+ // ~/.ouro-cli/versions/ — the user observed installs going back to
596
+ // alpha.85 from March 20 (~100MB of dead node_modules trees).
597
+ // pruneOldVersions keeps the 5 most recent + the active + the
598
+ // previous version, so rollback stays one command away.
599
+ (0, ouro_version_manager_1.pruneOldVersions)(undefined, {});
600
+ },
601
+ /* v8 ignore stop */
602
+ /* v8 ignore start -- CLI version management defaults: integration code @preserve */
603
+ checkForCliUpdate: async () => {
604
+ const { checkForUpdate } = await Promise.resolve().then(() => __importStar(require("../versioning/update-checker")));
605
+ return checkForUpdate((0, bundle_manifest_1.getPackageVersion)(), {
606
+ fetchRegistryJson: () => defaultFetchCliRegistryJson(update_checker_1.CLI_UPDATE_CHECK_TIMEOUT_MS),
607
+ distTag: update_checker_1.CLI_UPDATE_DIST_TAG,
608
+ });
609
+ },
610
+ installCliVersion: async (version) => { (0, ouro_version_manager_1.installVersion)(version, {}); },
611
+ activateCliVersion: (version) => {
612
+ (0, ouro_version_manager_1.activateVersion)(version, {});
613
+ // Same self-prune as ensureCurrentVersionInstalled — fires from the
614
+ // checkForCliUpdate path 1 (in-process update detected → activate
615
+ // → re-exec). Without this, the path 1 code path never triggers
616
+ // a prune.
617
+ (0, ouro_version_manager_1.pruneOldVersions)(undefined, {});
618
+ },
619
+ getCurrentCliVersion: () => (0, ouro_version_manager_1.getCurrentVersion)({}),
620
+ getPreviousCliVersion: () => (0, ouro_version_manager_1.getPreviousVersion)({}),
621
+ listCliVersions: () => (0, ouro_version_manager_1.listInstalledVersions)({}),
622
+ reExecFromNewVersion: (reArgs) => {
623
+ const entry = path.join((0, ouro_version_manager_1.getOuroCliHome)(), "CurrentVersion", "node_modules", "@ouro.bot", "cli", "dist", "heart", "daemon", "ouro-entry.js");
624
+ require("child_process").execFileSync("node", [entry, ...reArgs], { stdio: "inherit" });
625
+ process.exit(0);
626
+ },
627
+ /* v8 ignore stop */
628
+ syncGlobalOuroBotWrapper: ouro_bot_global_installer_1.syncGlobalOuroBotWrapper,
629
+ pruneDaemonLogs: logs_prune_1.pruneDaemonLogs,
630
+ ensureSkillManagement: skill_management_installer_1.ensureSkillManagement,
631
+ prepareDaemonRuntimeReplacement: defaultPrepareDaemonRuntimeReplacement,
632
+ ensureDaemonBootPersistence: defaultEnsureDaemonBootPersistence,
633
+ /* v8 ignore start -- dev-mode defaults: tests inject mocks for mode detection and binary resolution @preserve */
634
+ detectMode: () => (0, runtime_mode_1.detectRuntimeMode)((0, identity_1.getRepoRoot)()),
635
+ getInstalledBinaryPath: () => {
636
+ const cliHome = (0, ouro_version_manager_1.getOuroCliHome)();
637
+ const binaryPath = path.join(cliHome, "bin", "ouro");
638
+ return fs.existsSync(binaryPath) ? binaryPath : null;
639
+ },
640
+ execInstalledBinary: (binaryPath, binArgs) => {
641
+ const { execFileSync } = require("child_process");
642
+ execFileSync(binaryPath, binArgs, { stdio: "inherit" });
643
+ process.exit(0);
644
+ },
645
+ /* v8 ignore stop */
646
+ /* v8 ignore next 3 -- integration: launches interactive CLI session @preserve */
647
+ startChat: async (agentName) => {
648
+ const { main } = await Promise.resolve().then(() => __importStar(require("../../senses/cli")));
649
+ await main(agentName);
650
+ },
651
+ scanSessions: async (agentName) => {
652
+ const agentRoot = (0, identity_1.getAgentRoot)(agentName);
653
+ return (0, session_activity_1.listSessionActivity)({
654
+ sessionsDir: path.join(agentRoot, "state", "sessions"),
655
+ friendsDir: path.join(agentRoot, "friends"),
656
+ agentName,
657
+ }).map((entry) => ({
658
+ friendId: entry.friendId,
659
+ friendName: entry.friendName,
660
+ channel: entry.channel,
661
+ lastActivity: entry.lastActivityAt,
662
+ }));
663
+ },
664
+ };
665
+ }