@ouro.bot/cli 0.1.0-alpha.45 → 0.1.0-alpha.451

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 (348) hide show
  1. package/README.md +127 -19
  2. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +3 -2
  3. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
  4. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  5. package/changelog.json +2861 -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 +490 -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 +216 -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 +631 -0
  44. package/dist/heart/daemon/cli-exec.js +6026 -0
  45. package/dist/heart/daemon/cli-help.js +445 -0
  46. package/dist/heart/daemon/cli-parse.js +1197 -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 +323 -0
  51. package/dist/heart/daemon/daemon-cli.js +29 -1617
  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 +190 -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 +234 -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 +394 -0
  67. package/dist/heart/daemon/launchd.js +25 -5
  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/provider-ping-progress.js +83 -0
  77. package/dist/heart/daemon/pulse.js +475 -0
  78. package/dist/heart/daemon/readiness-repair.js +365 -0
  79. package/dist/heart/daemon/run-hooks.js +2 -0
  80. package/dist/heart/daemon/runtime-logging.js +67 -16
  81. package/dist/heart/daemon/runtime-metadata.js +73 -0
  82. package/dist/heart/daemon/runtime-mode.js +67 -0
  83. package/dist/heart/daemon/safe-mode.js +161 -0
  84. package/dist/heart/daemon/sense-manager.js +152 -36
  85. package/dist/heart/daemon/session-id-resolver.js +131 -0
  86. package/dist/heart/daemon/skill-management-installer.js +94 -0
  87. package/dist/heart/daemon/socket-client.js +307 -0
  88. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  89. package/dist/heart/daemon/startup-tui.js +264 -0
  90. package/dist/heart/daemon/task-scheduler.js +3 -25
  91. package/dist/heart/daemon/terminal-ui.js +499 -0
  92. package/dist/heart/daemon/thoughts.js +510 -0
  93. package/dist/heart/daemon/up-progress.js +366 -0
  94. package/dist/heart/delegation.js +62 -0
  95. package/dist/heart/habits/habit-migration.js +189 -0
  96. package/dist/heart/habits/habit-parser.js +140 -0
  97. package/dist/heart/habits/habit-runtime-state.js +100 -0
  98. package/dist/heart/habits/habit-scheduler.js +372 -0
  99. package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
  100. package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
  101. package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
  102. package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
  103. package/dist/heart/identity.js +201 -66
  104. package/dist/heart/kept-notes.js +357 -0
  105. package/dist/heart/kicks.js +1 -1
  106. package/dist/heart/machine-identity.js +161 -0
  107. package/dist/heart/mcp/mcp-server.js +653 -0
  108. package/dist/heart/migrate-config.js +100 -0
  109. package/dist/heart/model-capabilities.js +59 -0
  110. package/dist/heart/outlook/outlook-http-hooks.js +66 -0
  111. package/dist/heart/outlook/outlook-http-response.js +7 -0
  112. package/dist/heart/outlook/outlook-http-routes.js +244 -0
  113. package/dist/heart/outlook/outlook-http-static.js +99 -0
  114. package/dist/heart/outlook/outlook-http-transport.js +116 -0
  115. package/dist/heart/outlook/outlook-http.js +99 -0
  116. package/dist/heart/outlook/outlook-read.js +31 -0
  117. package/dist/heart/outlook/outlook-types.js +27 -0
  118. package/dist/heart/outlook/outlook-view.js +195 -0
  119. package/dist/heart/outlook/readers/agent-machine.js +359 -0
  120. package/dist/heart/outlook/readers/continuity-readers.js +332 -0
  121. package/dist/heart/outlook/readers/mail.js +203 -0
  122. package/dist/heart/outlook/readers/runtime-readers.js +644 -0
  123. package/dist/heart/outlook/readers/sessions.js +232 -0
  124. package/dist/heart/outlook/readers/shared.js +111 -0
  125. package/dist/heart/platform.js +81 -0
  126. package/dist/heart/progress-story.js +42 -0
  127. package/dist/heart/provider-attempt.js +134 -0
  128. package/dist/heart/provider-binding-resolver.js +255 -0
  129. package/dist/heart/provider-credentials.js +424 -0
  130. package/dist/heart/provider-failover.js +266 -0
  131. package/dist/heart/provider-models.js +81 -0
  132. package/dist/heart/provider-ping.js +262 -0
  133. package/dist/heart/provider-state.js +216 -0
  134. package/dist/heart/provider-visibility.js +188 -0
  135. package/dist/heart/providers/anthropic-token.js +131 -0
  136. package/dist/heart/providers/anthropic.js +193 -55
  137. package/dist/heart/providers/azure.js +103 -12
  138. package/dist/heart/providers/error-classification.js +63 -0
  139. package/dist/heart/providers/github-copilot.js +145 -0
  140. package/dist/heart/providers/minimax-vlm.js +189 -0
  141. package/dist/heart/providers/minimax.js +29 -7
  142. package/dist/heart/providers/openai-codex.js +62 -38
  143. package/dist/heart/runtime-capability-check.js +170 -0
  144. package/dist/heart/runtime-credentials.js +260 -0
  145. package/dist/heart/sense-truth.js +11 -4
  146. package/dist/heart/session-activity.js +190 -0
  147. package/dist/heart/session-events.js +855 -0
  148. package/dist/heart/session-transcript.js +167 -0
  149. package/dist/heart/start-of-turn-packet.js +345 -0
  150. package/dist/heart/streaming.js +36 -27
  151. package/dist/heart/sync.js +332 -0
  152. package/dist/heart/target-resolution.js +127 -0
  153. package/dist/heart/tempo.js +93 -0
  154. package/dist/heart/temporal-view.js +41 -0
  155. package/dist/heart/tool-activity-callbacks.js +36 -0
  156. package/dist/heart/tool-description.js +135 -0
  157. package/dist/heart/tool-friction.js +55 -0
  158. package/dist/heart/tool-loop.js +200 -0
  159. package/dist/heart/turn-context.js +361 -0
  160. package/dist/heart/turn-coordinator.js +28 -0
  161. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +1 -1
  162. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  163. package/dist/heart/versioning/ouro-path-installer.js +425 -0
  164. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  165. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  166. package/dist/heart/{daemon → versioning}/update-checker.js +5 -1
  167. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  168. package/dist/mailroom/blob-store.js +154 -0
  169. package/dist/mailroom/core.js +387 -0
  170. package/dist/mailroom/entry.js +160 -0
  171. package/dist/mailroom/file-store.js +230 -0
  172. package/dist/mailroom/mbox-import.js +105 -0
  173. package/dist/mailroom/reader.js +150 -0
  174. package/dist/mailroom/smtp-ingress.js +176 -0
  175. package/dist/mind/bundle-manifest.js +7 -1
  176. package/dist/mind/context.js +132 -93
  177. package/dist/mind/diary-integrity.js +60 -0
  178. package/dist/mind/{memory.js → diary.js} +74 -93
  179. package/dist/mind/embedding-provider.js +60 -0
  180. package/dist/mind/file-state.js +179 -0
  181. package/dist/mind/friends/channel.js +30 -0
  182. package/dist/mind/friends/group-context.js +144 -0
  183. package/dist/mind/friends/resolver.js +38 -1
  184. package/dist/mind/friends/store-file.js +39 -3
  185. package/dist/mind/friends/trust-explanation.js +74 -0
  186. package/dist/mind/friends/types.js +2 -2
  187. package/dist/mind/journal-index.js +161 -0
  188. package/dist/mind/note-search.js +268 -0
  189. package/dist/mind/obligation-steering.js +221 -0
  190. package/dist/mind/pending.js +66 -7
  191. package/dist/mind/prompt-refresh.js +3 -2
  192. package/dist/mind/prompt.js +963 -169
  193. package/dist/mind/provenance-trust.js +26 -0
  194. package/dist/mind/scrutiny.js +173 -0
  195. package/dist/nerves/cli-logging.js +7 -1
  196. package/dist/nerves/coverage/audit-rules.js +15 -6
  197. package/dist/nerves/coverage/audit.js +28 -2
  198. package/dist/nerves/coverage/cli.js +1 -1
  199. package/dist/nerves/coverage/contract.js +5 -5
  200. package/dist/nerves/coverage/file-completeness.js +83 -5
  201. package/dist/nerves/coverage/run-artifacts.js +1 -1
  202. package/dist/nerves/event-buffer.js +111 -0
  203. package/dist/nerves/index.js +224 -4
  204. package/dist/nerves/observation.js +20 -0
  205. package/dist/nerves/redact.js +79 -0
  206. package/dist/nerves/runtime.js +5 -1
  207. package/dist/outlook-ui/assets/index-BXw3xmUo.js +61 -0
  208. package/dist/outlook-ui/assets/index-D4Wg-o8Z.css +1 -0
  209. package/dist/outlook-ui/index.html +15 -0
  210. package/dist/repertoire/ado-client.js +15 -56
  211. package/dist/repertoire/ado-semantic.js +11 -10
  212. package/dist/repertoire/api-client.js +97 -0
  213. package/dist/repertoire/bitwarden-store.js +774 -0
  214. package/dist/repertoire/bundle-templates.js +72 -0
  215. package/dist/repertoire/bw-installer.js +180 -0
  216. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  217. package/dist/repertoire/coding/context-pack.js +330 -0
  218. package/dist/repertoire/coding/feedback.js +197 -30
  219. package/dist/repertoire/coding/manager.js +158 -9
  220. package/dist/repertoire/coding/spawner.js +55 -9
  221. package/dist/repertoire/coding/tools.js +170 -7
  222. package/dist/repertoire/commerce-errors.js +109 -0
  223. package/dist/repertoire/commerce-self-test.js +156 -0
  224. package/dist/repertoire/credential-access.js +111 -0
  225. package/dist/repertoire/duffel-client.js +185 -0
  226. package/dist/repertoire/github-client.js +14 -55
  227. package/dist/repertoire/graph-client.js +11 -52
  228. package/dist/repertoire/guardrails.js +371 -0
  229. package/dist/repertoire/mcp-client.js +255 -0
  230. package/dist/repertoire/mcp-manager.js +305 -0
  231. package/dist/repertoire/mcp-tools.js +63 -0
  232. package/dist/repertoire/shell-sessions.js +133 -0
  233. package/dist/repertoire/skills.js +15 -24
  234. package/dist/repertoire/stripe-client.js +131 -0
  235. package/dist/repertoire/tasks/board.js +43 -5
  236. package/dist/repertoire/tasks/fix.js +182 -0
  237. package/dist/repertoire/tasks/index.js +37 -4
  238. package/dist/repertoire/tasks/lifecycle.js +2 -2
  239. package/dist/repertoire/tasks/parser.js +3 -2
  240. package/dist/repertoire/tasks/scanner.js +194 -37
  241. package/dist/repertoire/tasks/transitions.js +16 -78
  242. package/dist/repertoire/tool-results.js +29 -0
  243. package/dist/repertoire/tools-attachments.js +317 -0
  244. package/dist/repertoire/tools-base.js +42 -690
  245. package/dist/repertoire/tools-bluebubbles.js +1 -0
  246. package/dist/repertoire/tools-bridge.js +141 -0
  247. package/dist/repertoire/tools-bundle.js +984 -0
  248. package/dist/repertoire/tools-config.js +185 -0
  249. package/dist/repertoire/tools-continuity.js +248 -0
  250. package/dist/repertoire/tools-credential.js +361 -0
  251. package/dist/repertoire/tools-files.js +342 -0
  252. package/dist/repertoire/tools-flight.js +224 -0
  253. package/dist/repertoire/tools-flow.js +105 -0
  254. package/dist/repertoire/tools-github.js +1 -7
  255. package/dist/repertoire/tools-mail.js +209 -0
  256. package/dist/repertoire/tools-notes.js +376 -0
  257. package/dist/repertoire/tools-session.js +739 -0
  258. package/dist/repertoire/tools-shell.js +120 -0
  259. package/dist/repertoire/tools-stripe.js +180 -0
  260. package/dist/repertoire/tools-surface.js +243 -0
  261. package/dist/repertoire/tools-teams.js +9 -39
  262. package/dist/repertoire/tools-travel.js +125 -0
  263. package/dist/repertoire/tools-user-profile.js +144 -0
  264. package/dist/repertoire/tools-vault.js +40 -0
  265. package/dist/repertoire/tools.js +144 -113
  266. package/dist/repertoire/travel-api-client.js +360 -0
  267. package/dist/repertoire/user-profile.js +131 -0
  268. package/dist/repertoire/vault-setup.js +246 -0
  269. package/dist/repertoire/vault-unlock.js +561 -0
  270. package/dist/scripts/claude-code-hook.js +41 -0
  271. package/dist/scripts/claude-code-stop-hook.js +47 -0
  272. package/dist/senses/attention-queue.js +116 -0
  273. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  274. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  275. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
  276. package/dist/senses/bluebubbles/entry.js +73 -0
  277. package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +7 -3
  278. package/dist/senses/bluebubbles/index.js +1620 -0
  279. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  280. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
  281. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
  282. package/dist/senses/bluebubbles/replay.js +129 -0
  283. package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +2 -2
  284. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  285. package/dist/senses/cli/bracketed-paste.js +82 -0
  286. package/dist/senses/cli/image-paste.js +287 -0
  287. package/dist/senses/cli/image-ref-navigation.js +75 -0
  288. package/dist/senses/cli/ink-app.js +156 -0
  289. package/dist/senses/cli/inline-diff.js +64 -0
  290. package/dist/senses/cli/input-keys.js +174 -0
  291. package/dist/senses/cli/kill-ring.js +86 -0
  292. package/dist/senses/cli/message-list.js +51 -0
  293. package/dist/senses/cli/ouro-tui.js +605 -0
  294. package/dist/senses/cli/spinner-imperative.js +135 -0
  295. package/dist/senses/cli/spinner.js +101 -0
  296. package/dist/senses/cli/status-line.js +60 -0
  297. package/dist/senses/cli/streaming-markdown.js +526 -0
  298. package/dist/senses/cli/tool-display.js +83 -0
  299. package/dist/senses/cli/tool-render.js +85 -0
  300. package/dist/senses/cli/tui-store.js +240 -0
  301. package/dist/senses/cli/virtual-list.js +35 -0
  302. package/dist/senses/cli-entry.js +60 -8
  303. package/dist/senses/cli-layout.js +187 -0
  304. package/dist/senses/cli.js +516 -211
  305. package/dist/senses/commands.js +66 -3
  306. package/dist/senses/habit-turn-message.js +108 -0
  307. package/dist/senses/inner-dialog-worker.js +102 -19
  308. package/dist/senses/inner-dialog.js +597 -95
  309. package/dist/senses/pipeline.js +533 -72
  310. package/dist/senses/proactive-content-guard.js +51 -0
  311. package/dist/senses/shared-turn.js +205 -0
  312. package/dist/senses/surface-tool.js +68 -0
  313. package/dist/senses/teams-entry.js +60 -8
  314. package/dist/senses/teams.js +413 -163
  315. package/dist/senses/trust-gate.js +5 -5
  316. package/package.json +37 -7
  317. package/skills/agent-commerce.md +106 -0
  318. package/skills/browser-navigation.md +117 -0
  319. package/skills/commerce-setup-guide.md +116 -0
  320. package/skills/commerce-setup.md +84 -0
  321. package/skills/configure-dev-tools.md +101 -0
  322. package/skills/travel-planning.md +138 -0
  323. package/dist/heart/daemon/ouro-path-installer.js +0 -178
  324. package/dist/heart/daemon/subagent-installer.js +0 -166
  325. package/dist/mind/associative-recall.js +0 -209
  326. package/dist/senses/bluebubbles-entry.js +0 -13
  327. package/dist/senses/bluebubbles.js +0 -1028
  328. package/dist/senses/debug-activity.js +0 -127
  329. package/subagents/README.md +0 -86
  330. package/subagents/work-doer.md +0 -237
  331. package/subagents/work-merger.md +0 -618
  332. package/subagents/work-planner.md +0 -390
  333. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  334. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  335. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  336. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  337. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  338. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  339. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  340. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  341. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  342. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  343. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  344. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  345. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  346. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  347. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  348. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
@@ -33,14 +33,24 @@ var __importStar = (this && this.__importStar) || (function () {
33
33
  };
34
34
  })();
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.DEFAULT_AGENT_SENSES = exports.DEFAULT_AGENT_PHRASES = exports.DEFAULT_AGENT_CONTEXT = void 0;
36
+ exports.HARNESS_CANONICAL_REPO_URL = exports.DEFAULT_AGENT_SENSES = exports.LEGACY_VAULT_SERVER_URL_ALIASES = exports.DEFAULT_VAULT_SERVER_URL = exports.DEFAULT_AGENT_PHRASES = exports.DEFAULT_AGENT_CONTEXT = exports.PROVIDER_CREDENTIALS = void 0;
37
+ exports.normalizeVaultServerUrl = normalizeVaultServerUrl;
38
+ exports.getVaultServerUrlCandidates = getVaultServerUrlCandidates;
39
+ exports.defaultStableVaultEmail = defaultStableVaultEmail;
40
+ exports.resolveVaultConfig = resolveVaultConfig;
41
+ exports.normalizeSenses = normalizeSenses;
37
42
  exports.buildDefaultAgentTemplate = buildDefaultAgentTemplate;
38
43
  exports.getAgentName = getAgentName;
39
44
  exports.getRepoRoot = getRepoRoot;
40
45
  exports.getAgentBundlesRoot = getAgentBundlesRoot;
41
46
  exports.getAgentRoot = getAgentRoot;
42
47
  exports.getAgentStateRoot = getAgentStateRoot;
43
- exports.getAgentSecretsPath = getAgentSecretsPath;
48
+ exports.getAgentRepoWorkspacesRoot = getAgentRepoWorkspacesRoot;
49
+ exports.getAgentDaemonStateRoot = getAgentDaemonStateRoot;
50
+ exports.getAgentDaemonLogsDir = getAgentDaemonLogsDir;
51
+ exports.getAgentDaemonLoggingConfigPath = getAgentDaemonLoggingConfigPath;
52
+ exports.getAgentMessagesRoot = getAgentMessagesRoot;
53
+ exports.getAgentToolsRoot = getAgentToolsRoot;
44
54
  exports.loadAgentConfig = loadAgentConfig;
45
55
  exports.setAgentName = setAgentName;
46
56
  exports.setAgentConfigOverride = setAgentConfigOverride;
@@ -50,6 +60,15 @@ const fs = __importStar(require("fs"));
50
60
  const os = __importStar(require("os"));
51
61
  const path = __importStar(require("path"));
52
62
  const runtime_1 = require("../nerves/runtime");
63
+ const migrate_config_1 = require("./migrate-config");
64
+ /** Single source of truth for per-provider credential field names, env var mappings, and prompt labels. */
65
+ exports.PROVIDER_CREDENTIALS = {
66
+ anthropic: { required: ["setupToken"], envVars: { ANTHROPIC_API_KEY: "setupToken" }, promptLabels: { setupToken: "Anthropic setup-token" } },
67
+ "openai-codex": { required: ["oauthAccessToken"], envVars: { OPENAI_API_KEY: "oauthAccessToken" }, promptLabels: { oauthAccessToken: "OpenAI Codex OAuth token" } },
68
+ azure: { required: ["apiKey", "endpoint", "deployment"], envVars: { AZURE_OPENAI_API_KEY: "apiKey", AZURE_OPENAI_KEY: "apiKey", AZURE_OPENAI_ENDPOINT: "endpoint", AZURE_OPENAI_DEPLOYMENT: "deployment" }, promptLabels: { apiKey: "Azure API key", endpoint: "Azure endpoint", deployment: "Azure deployment" } },
69
+ minimax: { required: ["apiKey"], envVars: { MINIMAX_API_KEY: "apiKey" }, promptLabels: { apiKey: "MiniMax API key" } },
70
+ "github-copilot": { required: ["githubToken", "baseUrl"], envVars: { GH_TOKEN: "githubToken", GITHUB_TOKEN: "githubToken" }, promptLabels: { githubToken: "GitHub token" } },
71
+ };
53
72
  exports.DEFAULT_AGENT_CONTEXT = {
54
73
  maxTokens: 80000,
55
74
  contextMargin: 20,
@@ -59,16 +78,70 @@ exports.DEFAULT_AGENT_PHRASES = {
59
78
  tool: ["running tool"],
60
79
  followup: ["processing"],
61
80
  };
81
+ exports.DEFAULT_VAULT_SERVER_URL = "https://vault.ouroboros.bot";
82
+ exports.LEGACY_VAULT_SERVER_URL_ALIASES = [
83
+ "https://vault.ouro.bot",
84
+ "https://ouro-vault.gentleflower-74452a1e.eastus2.azurecontainerapps.io",
85
+ ];
86
+ function normalizeVaultServerUrl(serverUrl) {
87
+ const trimmed = serverUrl.trim();
88
+ const withoutTrailingSlash = trimmed.replace(/\/+$/, "");
89
+ if (!withoutTrailingSlash) {
90
+ return exports.DEFAULT_VAULT_SERVER_URL;
91
+ }
92
+ if (exports.LEGACY_VAULT_SERVER_URL_ALIASES.includes(withoutTrailingSlash)) {
93
+ return exports.DEFAULT_VAULT_SERVER_URL;
94
+ }
95
+ return withoutTrailingSlash;
96
+ }
97
+ function getVaultServerUrlCandidates(serverUrl) {
98
+ const raw = serverUrl.trim();
99
+ const withoutTrailingSlash = raw.replace(/\/+$/, "");
100
+ const normalized = normalizeVaultServerUrl(serverUrl);
101
+ const candidates = [normalized];
102
+ for (const candidate of [withoutTrailingSlash, raw]) {
103
+ if (candidate && !candidates.includes(candidate)) {
104
+ candidates.push(candidate);
105
+ }
106
+ }
107
+ if (normalized === exports.DEFAULT_VAULT_SERVER_URL) {
108
+ for (const alias of exports.LEGACY_VAULT_SERVER_URL_ALIASES) {
109
+ if (!candidates.includes(alias)) {
110
+ candidates.push(alias);
111
+ }
112
+ }
113
+ }
114
+ return candidates;
115
+ }
116
+ function defaultStableVaultEmail(agentName) {
117
+ const local = agentName
118
+ .toLowerCase()
119
+ .replace(/[^a-z0-9._-]+/g, "-")
120
+ .replace(/^-+|-+$/g, "") || "agent";
121
+ return `${local}@ouro.bot`;
122
+ }
123
+ /**
124
+ * Resolve the vault config for an agent, applying defaults.
125
+ * If vault is not configured in agent.json, returns default values.
126
+ */
127
+ function resolveVaultConfig(agentName, config) {
128
+ return {
129
+ email: config?.email ?? defaultStableVaultEmail(agentName),
130
+ serverUrl: normalizeVaultServerUrl(config?.serverUrl ?? exports.DEFAULT_VAULT_SERVER_URL),
131
+ };
132
+ }
62
133
  exports.DEFAULT_AGENT_SENSES = {
63
134
  cli: { enabled: true },
64
135
  teams: { enabled: false },
65
136
  bluebubbles: { enabled: false },
137
+ mail: { enabled: false },
66
138
  };
67
139
  function normalizeSenses(value, configFile) {
68
140
  const defaults = {
69
141
  cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
70
142
  teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
71
143
  bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
144
+ mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
72
145
  };
73
146
  if (value === undefined) {
74
147
  return defaults;
@@ -84,7 +157,7 @@ function normalizeSenses(value, configFile) {
84
157
  throw new Error(`agent.json at ${configFile} must include senses as an object when present.`);
85
158
  }
86
159
  const raw = value;
87
- const senseNames = ["cli", "teams", "bluebubbles"];
160
+ const senseNames = ["cli", "teams", "bluebubbles", "mail"];
88
161
  for (const senseName of senseNames) {
89
162
  const rawSense = raw[senseName];
90
163
  if (rawSense === undefined) {
@@ -117,14 +190,16 @@ function normalizeSenses(value, configFile) {
117
190
  }
118
191
  function buildDefaultAgentTemplate(_agentName) {
119
192
  return {
120
- version: 1,
193
+ version: 2,
121
194
  enabled: true,
122
- provider: "anthropic",
195
+ humanFacing: { provider: "anthropic", model: "claude-opus-4-6" },
196
+ agentFacing: { provider: "anthropic", model: "claude-opus-4-6" },
123
197
  context: { ...exports.DEFAULT_AGENT_CONTEXT },
124
198
  senses: {
125
199
  cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
126
200
  teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
127
201
  bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
202
+ mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
128
203
  },
129
204
  phrases: {
130
205
  thinking: [...exports.DEFAULT_AGENT_PHRASES.thinking],
@@ -134,7 +209,6 @@ function buildDefaultAgentTemplate(_agentName) {
134
209
  };
135
210
  }
136
211
  let _cachedAgentName = null;
137
- let _cachedAgentConfig = null;
138
212
  let _agentConfigOverride = null;
139
213
  /**
140
214
  * Parse `--agent <name>` from process.argv.
@@ -185,38 +259,46 @@ function getAgentBundlesRoot() {
185
259
  function getAgentRoot(agentName = getAgentName()) {
186
260
  return path.join(getAgentBundlesRoot(), `${agentName}.ouro`);
187
261
  }
262
+ function resolveOptionalAgentName(agentName) {
263
+ if (agentName && agentName.trim().length > 0)
264
+ return agentName.trim();
265
+ try {
266
+ return getAgentName();
267
+ }
268
+ catch {
269
+ return "slugger";
270
+ }
271
+ }
188
272
  /**
189
273
  * Returns the bundle-local runtime state directory: `~/AgentBundles/<agentName>.ouro/state/`
190
274
  */
191
- function getAgentStateRoot(agentName = getAgentName()) {
192
- return path.join(getAgentRoot(agentName), "state");
275
+ function getAgentStateRoot(agentName) {
276
+ return path.join(getAgentRoot(resolveOptionalAgentName(agentName)), "state");
193
277
  }
194
- /**
195
- * Returns the conventional secrets path: `~/.agentsecrets/<agentName>/secrets.json`
196
- */
197
- function getAgentSecretsPath(agentName = getAgentName()) {
198
- return path.join(os.homedir(), ".agentsecrets", agentName, "secrets.json");
278
+ exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/ouroborosbot/ouroboros.git";
279
+ function getAgentRepoWorkspacesRoot(agentName) {
280
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "workspaces");
199
281
  }
200
- /**
201
- * Load and parse `<agentRoot>/agent.json`.
202
- * Caches the result after first load.
203
- * Throws descriptive error if file is missing or contains invalid JSON.
204
- */
205
- function loadAgentConfig() {
206
- if (_agentConfigOverride) {
207
- return _agentConfigOverride;
208
- }
209
- if (_cachedAgentConfig) {
210
- (0, runtime_1.emitNervesEvent)({
211
- event: "identity.resolve",
212
- component: "config/identity",
213
- message: "loaded agent config from cache",
214
- meta: { source: "cache" },
215
- });
216
- return _cachedAgentConfig;
217
- }
218
- const agentRoot = getAgentRoot();
219
- const configFile = path.join(agentRoot, "agent.json");
282
+ function getAgentDaemonStateRoot(agentName) {
283
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "daemon");
284
+ }
285
+ function getAgentDaemonLogsDir(agentName) {
286
+ return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logs");
287
+ }
288
+ function getAgentDaemonLoggingConfigPath(agentName) {
289
+ return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logging.json");
290
+ }
291
+ function getAgentMessagesRoot(agentName) {
292
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "messages");
293
+ }
294
+ function getAgentToolsRoot(agentName) {
295
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "tools");
296
+ }
297
+ const VALID_PROVIDERS = ["azure", "minimax", "anthropic", "openai-codex", "github-copilot"];
298
+ function isValidProvider(value) {
299
+ return typeof value === "string" && VALID_PROVIDERS.includes(value);
300
+ }
301
+ function readAndParseAgentJson(configFile) {
220
302
  let raw;
221
303
  try {
222
304
  raw = fs.readFileSync(configFile, "utf-8");
@@ -234,9 +316,8 @@ function loadAgentConfig() {
234
316
  });
235
317
  throw new Error(`Cannot read agent.json at ${configFile}. Does the agent directory exist?`);
236
318
  }
237
- let parsed;
238
319
  try {
239
- parsed = JSON.parse(raw);
320
+ return JSON.parse(raw);
240
321
  }
241
322
  catch (error) {
242
323
  (0, runtime_1.emitNervesEvent)({
@@ -251,6 +332,62 @@ function loadAgentConfig() {
251
332
  });
252
333
  throw new Error(`Invalid JSON in agent.json at ${configFile}. Check syntax.`);
253
334
  }
335
+ }
336
+ function validateFacingConfig(parsed, facingName, configFile) {
337
+ const raw = parsed[facingName];
338
+ if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
339
+ (0, runtime_1.emitNervesEvent)({
340
+ level: "error",
341
+ event: "config_identity.error",
342
+ component: "config/identity",
343
+ message: `agent config missing or invalid ${facingName}`,
344
+ meta: { path: configFile, [facingName]: raw ?? null },
345
+ });
346
+ throw new Error(`agent.json at ${configFile} must include ${facingName} as { provider, model }.`);
347
+ }
348
+ const facing = raw;
349
+ if (!isValidProvider(facing.provider)) {
350
+ (0, runtime_1.emitNervesEvent)({
351
+ level: "error",
352
+ event: "config_identity.error",
353
+ component: "config/identity",
354
+ message: `agent config has invalid provider in ${facingName}`,
355
+ meta: { path: configFile, provider: facing.provider ?? null },
356
+ });
357
+ throw new Error(`agent.json at ${configFile} ${facingName}.provider must be one of: ${VALID_PROVIDERS.join(", ")}.`);
358
+ }
359
+ if (typeof facing.model !== "string") {
360
+ (0, runtime_1.emitNervesEvent)({
361
+ level: "error",
362
+ event: "config_identity.error",
363
+ component: "config/identity",
364
+ message: `agent config has invalid model in ${facingName}`,
365
+ meta: { path: configFile, model: facing.model ?? null },
366
+ });
367
+ throw new Error(`agent.json at ${configFile} ${facingName}.model must be a string.`);
368
+ }
369
+ return { provider: facing.provider, model: facing.model };
370
+ }
371
+ /**
372
+ * Load and parse `<agentRoot>/agent.json`.
373
+ * Reads the file fresh on each call unless an override is set.
374
+ * If the config is v1, auto-migrates to v2 via migrateAgentConfigV1ToV2 and re-reads.
375
+ * Throws descriptive error if file is missing or contains invalid JSON.
376
+ */
377
+ function loadAgentConfig() {
378
+ if (_agentConfigOverride) {
379
+ return _agentConfigOverride;
380
+ }
381
+ const agentRoot = getAgentRoot();
382
+ const configFile = path.join(agentRoot, "agent.json");
383
+ let parsed = readAndParseAgentJson(configFile);
384
+ // Inline migration: v1 -> v2
385
+ const rawVersion = parsed.version;
386
+ const initialVersion = typeof rawVersion === "number" ? rawVersion : 1;
387
+ if (initialVersion < 2) {
388
+ (0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
389
+ parsed = readAndParseAgentJson(configFile);
390
+ }
254
391
  const existingPhrases = parsed.phrases;
255
392
  const needsFill = !existingPhrases ||
256
393
  !existingPhrases.thinking ||
@@ -272,27 +409,11 @@ function loadAgentConfig() {
272
409
  });
273
410
  fs.writeFileSync(configFile, JSON.stringify(parsed, null, 2) + "\n", "utf-8");
274
411
  }
275
- const rawProvider = parsed.provider;
276
- if (rawProvider !== "azure" &&
277
- rawProvider !== "minimax" &&
278
- rawProvider !== "anthropic" &&
279
- rawProvider !== "openai-codex") {
280
- (0, runtime_1.emitNervesEvent)({
281
- level: "error",
282
- event: "config_identity.error",
283
- component: "config/identity",
284
- message: "agent config missing or invalid provider",
285
- meta: {
286
- path: configFile,
287
- provider: rawProvider,
288
- },
289
- });
290
- throw new Error(`agent.json at ${configFile} must include provider: "azure", "minimax", "anthropic", or "openai-codex".`);
291
- }
292
- const rawVersion = parsed.version;
293
- const version = rawVersion === undefined ? 1 : rawVersion;
294
- if (typeof version !== "number" ||
295
- !Number.isInteger(version) ||
412
+ // Validate v2 facing configs
413
+ const humanFacing = validateFacingConfig(parsed, "humanFacing", configFile);
414
+ const agentFacing = validateFacingConfig(parsed, "agentFacing", configFile);
415
+ const version = typeof parsed.version === "number" ? parsed.version : 1;
416
+ if (!Number.isInteger(version) ||
296
417
  version < 1) {
297
418
  (0, runtime_1.emitNervesEvent)({
298
419
  level: "error",
@@ -301,7 +422,7 @@ function loadAgentConfig() {
301
422
  message: "agent config missing or invalid version",
302
423
  meta: {
303
424
  path: configFile,
304
- version: rawVersion,
425
+ version: parsed.version,
305
426
  },
306
427
  });
307
428
  throw new Error(`agent.json at ${configFile} must include version as integer >= 1.`);
@@ -321,22 +442,37 @@ function loadAgentConfig() {
321
442
  });
322
443
  throw new Error(`agent.json at ${configFile} must include enabled as boolean.`);
323
444
  }
324
- _cachedAgentConfig = {
445
+ // Tolerate deprecated provider field for backward compatibility
446
+ const rawProvider = parsed.provider;
447
+ const provider = isValidProvider(rawProvider) ? rawProvider : undefined;
448
+ // Spread parsed first so any field present in AgentConfig is carried
449
+ // through by default, then explicitly override the fields that need
450
+ // validation or normalization. This eliminates the field-drop bug class
451
+ // that caused the `sync` block (and previously `shell`) to be silently
452
+ // omitted from the returned config. Regression-guarded by the
453
+ // Required<AgentConfig> contract test in identity-contract.test.ts.
454
+ const config = {
455
+ ...parsed,
325
456
  version,
326
457
  enabled,
327
- provider: rawProvider,
328
- context: parsed.context,
329
- logging: parsed.logging,
458
+ humanFacing,
459
+ agentFacing,
330
460
  senses: normalizeSenses(parsed.senses, configFile),
331
461
  phrases: parsed.phrases,
332
462
  };
463
+ if (provider !== undefined) {
464
+ config.provider = provider;
465
+ }
466
+ else {
467
+ delete config.provider;
468
+ }
333
469
  (0, runtime_1.emitNervesEvent)({
334
470
  event: "identity.resolve",
335
471
  component: "config/identity",
336
472
  message: "loaded agent config from disk",
337
473
  meta: { source: "disk" },
338
474
  });
339
- return _cachedAgentConfig;
475
+ return config;
340
476
  }
341
477
  /**
342
478
  * Prime the agent name cache explicitly.
@@ -356,11 +492,11 @@ function setAgentConfigOverride(config) {
356
492
  _agentConfigOverride = config;
357
493
  }
358
494
  /**
359
- * Clear only the cached agent config while preserving the resolved agent identity.
360
- * Used when a running agent should pick up updated disk-backed config on the next turn.
495
+ * Preserve the compatibility hook for callers that previously cleared cached
496
+ * disk-backed agent config. Agent config is now read fresh on every call.
361
497
  */
362
498
  function resetAgentConfigCache() {
363
- _cachedAgentConfig = null;
499
+ // No-op: disk-backed agent config is no longer memoized in-process.
364
500
  }
365
501
  /**
366
502
  * Clear all cached identity state.
@@ -368,6 +504,5 @@ function resetAgentConfigCache() {
368
504
  */
369
505
  function resetIdentity() {
370
506
  _cachedAgentName = null;
371
- _cachedAgentConfig = null;
372
507
  _agentConfigOverride = null;
373
508
  }