@ouro.bot/cli 0.1.0-alpha.43 → 0.1.0-alpha.431

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