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

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