@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
@@ -33,14 +33,22 @@ 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.DEFAULT_VAULT_SERVER_URL = exports.DEFAULT_AGENT_PHRASES = exports.DEFAULT_AGENT_CONTEXT = exports.PROVIDER_CREDENTIALS = void 0;
37
+ exports.defaultStableVaultEmail = defaultStableVaultEmail;
38
+ exports.resolveVaultConfig = resolveVaultConfig;
39
+ exports.normalizeSenses = normalizeSenses;
37
40
  exports.buildDefaultAgentTemplate = buildDefaultAgentTemplate;
38
41
  exports.getAgentName = getAgentName;
39
42
  exports.getRepoRoot = getRepoRoot;
40
43
  exports.getAgentBundlesRoot = getAgentBundlesRoot;
41
44
  exports.getAgentRoot = getAgentRoot;
42
45
  exports.getAgentStateRoot = getAgentStateRoot;
43
- exports.getAgentSecretsPath = getAgentSecretsPath;
46
+ exports.getAgentRepoWorkspacesRoot = getAgentRepoWorkspacesRoot;
47
+ exports.getAgentDaemonStateRoot = getAgentDaemonStateRoot;
48
+ exports.getAgentDaemonLogsDir = getAgentDaemonLogsDir;
49
+ exports.getAgentDaemonLoggingConfigPath = getAgentDaemonLoggingConfigPath;
50
+ exports.getAgentMessagesRoot = getAgentMessagesRoot;
51
+ exports.getAgentToolsRoot = getAgentToolsRoot;
44
52
  exports.loadAgentConfig = loadAgentConfig;
45
53
  exports.setAgentName = setAgentName;
46
54
  exports.setAgentConfigOverride = setAgentConfigOverride;
@@ -50,6 +58,15 @@ const fs = __importStar(require("fs"));
50
58
  const os = __importStar(require("os"));
51
59
  const path = __importStar(require("path"));
52
60
  const runtime_1 = require("../nerves/runtime");
61
+ const migrate_config_1 = require("./migrate-config");
62
+ /** Single source of truth for per-provider credential field names, env var mappings, and prompt labels. */
63
+ exports.PROVIDER_CREDENTIALS = {
64
+ anthropic: { required: ["setupToken"], envVars: { ANTHROPIC_API_KEY: "setupToken" }, promptLabels: { setupToken: "Anthropic setup-token" } },
65
+ "openai-codex": { required: ["oauthAccessToken"], envVars: { OPENAI_API_KEY: "oauthAccessToken" }, promptLabels: { oauthAccessToken: "OpenAI Codex OAuth token" } },
66
+ 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" } },
67
+ minimax: { required: ["apiKey"], envVars: { MINIMAX_API_KEY: "apiKey" }, promptLabels: { apiKey: "MiniMax API key" } },
68
+ "github-copilot": { required: ["githubToken", "baseUrl"], envVars: { GH_TOKEN: "githubToken", GITHUB_TOKEN: "githubToken" }, promptLabels: { githubToken: "GitHub token" } },
69
+ };
53
70
  exports.DEFAULT_AGENT_CONTEXT = {
54
71
  maxTokens: 80000,
55
72
  contextMargin: 20,
@@ -59,6 +76,24 @@ exports.DEFAULT_AGENT_PHRASES = {
59
76
  tool: ["running tool"],
60
77
  followup: ["processing"],
61
78
  };
79
+ exports.DEFAULT_VAULT_SERVER_URL = "https://vault.ouroboros.bot";
80
+ function defaultStableVaultEmail(agentName) {
81
+ const local = agentName
82
+ .toLowerCase()
83
+ .replace(/[^a-z0-9._-]+/g, "-")
84
+ .replace(/^-+|-+$/g, "") || "agent";
85
+ return `${local}@ouro.bot`;
86
+ }
87
+ /**
88
+ * Resolve the vault config for an agent, applying defaults.
89
+ * If vault is not configured in agent.json, returns default values.
90
+ */
91
+ function resolveVaultConfig(agentName, config) {
92
+ return {
93
+ email: config?.email ?? defaultStableVaultEmail(agentName),
94
+ serverUrl: config?.serverUrl ?? exports.DEFAULT_VAULT_SERVER_URL,
95
+ };
96
+ }
62
97
  exports.DEFAULT_AGENT_SENSES = {
63
98
  cli: { enabled: true },
64
99
  teams: { enabled: false },
@@ -117,9 +152,10 @@ function normalizeSenses(value, configFile) {
117
152
  }
118
153
  function buildDefaultAgentTemplate(_agentName) {
119
154
  return {
120
- version: 1,
155
+ version: 2,
121
156
  enabled: true,
122
- provider: "anthropic",
157
+ humanFacing: { provider: "anthropic", model: "claude-opus-4-6" },
158
+ agentFacing: { provider: "anthropic", model: "claude-opus-4-6" },
123
159
  context: { ...exports.DEFAULT_AGENT_CONTEXT },
124
160
  senses: {
125
161
  cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
@@ -134,7 +170,6 @@ function buildDefaultAgentTemplate(_agentName) {
134
170
  };
135
171
  }
136
172
  let _cachedAgentName = null;
137
- let _cachedAgentConfig = null;
138
173
  let _agentConfigOverride = null;
139
174
  /**
140
175
  * Parse `--agent <name>` from process.argv.
@@ -185,38 +220,46 @@ function getAgentBundlesRoot() {
185
220
  function getAgentRoot(agentName = getAgentName()) {
186
221
  return path.join(getAgentBundlesRoot(), `${agentName}.ouro`);
187
222
  }
223
+ function resolveOptionalAgentName(agentName) {
224
+ if (agentName && agentName.trim().length > 0)
225
+ return agentName.trim();
226
+ try {
227
+ return getAgentName();
228
+ }
229
+ catch {
230
+ return "slugger";
231
+ }
232
+ }
188
233
  /**
189
234
  * Returns the bundle-local runtime state directory: `~/AgentBundles/<agentName>.ouro/state/`
190
235
  */
191
- function getAgentStateRoot(agentName = getAgentName()) {
192
- return path.join(getAgentRoot(agentName), "state");
236
+ function getAgentStateRoot(agentName) {
237
+ return path.join(getAgentRoot(resolveOptionalAgentName(agentName)), "state");
193
238
  }
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");
239
+ exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/ouroborosbot/ouroboros.git";
240
+ function getAgentRepoWorkspacesRoot(agentName) {
241
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "workspaces");
199
242
  }
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");
243
+ function getAgentDaemonStateRoot(agentName) {
244
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "daemon");
245
+ }
246
+ function getAgentDaemonLogsDir(agentName) {
247
+ return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logs");
248
+ }
249
+ function getAgentDaemonLoggingConfigPath(agentName) {
250
+ return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logging.json");
251
+ }
252
+ function getAgentMessagesRoot(agentName) {
253
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "messages");
254
+ }
255
+ function getAgentToolsRoot(agentName) {
256
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "tools");
257
+ }
258
+ const VALID_PROVIDERS = ["azure", "minimax", "anthropic", "openai-codex", "github-copilot"];
259
+ function isValidProvider(value) {
260
+ return typeof value === "string" && VALID_PROVIDERS.includes(value);
261
+ }
262
+ function readAndParseAgentJson(configFile) {
220
263
  let raw;
221
264
  try {
222
265
  raw = fs.readFileSync(configFile, "utf-8");
@@ -234,9 +277,8 @@ function loadAgentConfig() {
234
277
  });
235
278
  throw new Error(`Cannot read agent.json at ${configFile}. Does the agent directory exist?`);
236
279
  }
237
- let parsed;
238
280
  try {
239
- parsed = JSON.parse(raw);
281
+ return JSON.parse(raw);
240
282
  }
241
283
  catch (error) {
242
284
  (0, runtime_1.emitNervesEvent)({
@@ -251,6 +293,62 @@ function loadAgentConfig() {
251
293
  });
252
294
  throw new Error(`Invalid JSON in agent.json at ${configFile}. Check syntax.`);
253
295
  }
296
+ }
297
+ function validateFacingConfig(parsed, facingName, configFile) {
298
+ const raw = parsed[facingName];
299
+ if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
300
+ (0, runtime_1.emitNervesEvent)({
301
+ level: "error",
302
+ event: "config_identity.error",
303
+ component: "config/identity",
304
+ message: `agent config missing or invalid ${facingName}`,
305
+ meta: { path: configFile, [facingName]: raw ?? null },
306
+ });
307
+ throw new Error(`agent.json at ${configFile} must include ${facingName} as { provider, model }.`);
308
+ }
309
+ const facing = raw;
310
+ if (!isValidProvider(facing.provider)) {
311
+ (0, runtime_1.emitNervesEvent)({
312
+ level: "error",
313
+ event: "config_identity.error",
314
+ component: "config/identity",
315
+ message: `agent config has invalid provider in ${facingName}`,
316
+ meta: { path: configFile, provider: facing.provider ?? null },
317
+ });
318
+ throw new Error(`agent.json at ${configFile} ${facingName}.provider must be one of: ${VALID_PROVIDERS.join(", ")}.`);
319
+ }
320
+ if (typeof facing.model !== "string") {
321
+ (0, runtime_1.emitNervesEvent)({
322
+ level: "error",
323
+ event: "config_identity.error",
324
+ component: "config/identity",
325
+ message: `agent config has invalid model in ${facingName}`,
326
+ meta: { path: configFile, model: facing.model ?? null },
327
+ });
328
+ throw new Error(`agent.json at ${configFile} ${facingName}.model must be a string.`);
329
+ }
330
+ return { provider: facing.provider, model: facing.model };
331
+ }
332
+ /**
333
+ * Load and parse `<agentRoot>/agent.json`.
334
+ * Reads the file fresh on each call unless an override is set.
335
+ * If the config is v1, auto-migrates to v2 via migrateAgentConfigV1ToV2 and re-reads.
336
+ * Throws descriptive error if file is missing or contains invalid JSON.
337
+ */
338
+ function loadAgentConfig() {
339
+ if (_agentConfigOverride) {
340
+ return _agentConfigOverride;
341
+ }
342
+ const agentRoot = getAgentRoot();
343
+ const configFile = path.join(agentRoot, "agent.json");
344
+ let parsed = readAndParseAgentJson(configFile);
345
+ // Inline migration: v1 -> v2
346
+ const rawVersion = parsed.version;
347
+ const initialVersion = typeof rawVersion === "number" ? rawVersion : 1;
348
+ if (initialVersion < 2) {
349
+ (0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
350
+ parsed = readAndParseAgentJson(configFile);
351
+ }
254
352
  const existingPhrases = parsed.phrases;
255
353
  const needsFill = !existingPhrases ||
256
354
  !existingPhrases.thinking ||
@@ -272,27 +370,11 @@ function loadAgentConfig() {
272
370
  });
273
371
  fs.writeFileSync(configFile, JSON.stringify(parsed, null, 2) + "\n", "utf-8");
274
372
  }
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) ||
373
+ // Validate v2 facing configs
374
+ const humanFacing = validateFacingConfig(parsed, "humanFacing", configFile);
375
+ const agentFacing = validateFacingConfig(parsed, "agentFacing", configFile);
376
+ const version = typeof parsed.version === "number" ? parsed.version : 1;
377
+ if (!Number.isInteger(version) ||
296
378
  version < 1) {
297
379
  (0, runtime_1.emitNervesEvent)({
298
380
  level: "error",
@@ -301,7 +383,7 @@ function loadAgentConfig() {
301
383
  message: "agent config missing or invalid version",
302
384
  meta: {
303
385
  path: configFile,
304
- version: rawVersion,
386
+ version: parsed.version,
305
387
  },
306
388
  });
307
389
  throw new Error(`agent.json at ${configFile} must include version as integer >= 1.`);
@@ -321,22 +403,37 @@ function loadAgentConfig() {
321
403
  });
322
404
  throw new Error(`agent.json at ${configFile} must include enabled as boolean.`);
323
405
  }
324
- _cachedAgentConfig = {
406
+ // Tolerate deprecated provider field for backward compatibility
407
+ const rawProvider = parsed.provider;
408
+ const provider = isValidProvider(rawProvider) ? rawProvider : undefined;
409
+ // Spread parsed first so any field present in AgentConfig is carried
410
+ // through by default, then explicitly override the fields that need
411
+ // validation or normalization. This eliminates the field-drop bug class
412
+ // that caused the `sync` block (and previously `shell`) to be silently
413
+ // omitted from the returned config. Regression-guarded by the
414
+ // Required<AgentConfig> contract test in identity-contract.test.ts.
415
+ const config = {
416
+ ...parsed,
325
417
  version,
326
418
  enabled,
327
- provider: rawProvider,
328
- context: parsed.context,
329
- logging: parsed.logging,
419
+ humanFacing,
420
+ agentFacing,
330
421
  senses: normalizeSenses(parsed.senses, configFile),
331
422
  phrases: parsed.phrases,
332
423
  };
424
+ if (provider !== undefined) {
425
+ config.provider = provider;
426
+ }
427
+ else {
428
+ delete config.provider;
429
+ }
333
430
  (0, runtime_1.emitNervesEvent)({
334
431
  event: "identity.resolve",
335
432
  component: "config/identity",
336
433
  message: "loaded agent config from disk",
337
434
  meta: { source: "disk" },
338
435
  });
339
- return _cachedAgentConfig;
436
+ return config;
340
437
  }
341
438
  /**
342
439
  * Prime the agent name cache explicitly.
@@ -356,11 +453,11 @@ function setAgentConfigOverride(config) {
356
453
  _agentConfigOverride = config;
357
454
  }
358
455
  /**
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.
456
+ * Preserve the compatibility hook for callers that previously cleared cached
457
+ * disk-backed agent config. Agent config is now read fresh on every call.
361
458
  */
362
459
  function resetAgentConfigCache() {
363
- _cachedAgentConfig = null;
460
+ // No-op: disk-backed agent config is no longer memoized in-process.
364
461
  }
365
462
  /**
366
463
  * Clear all cached identity state.
@@ -368,6 +465,5 @@ function resetAgentConfigCache() {
368
465
  */
369
466
  function resetIdentity() {
370
467
  _cachedAgentName = null;
371
- _cachedAgentConfig = null;
372
468
  _agentConfigOverride = null;
373
469
  }