@ouro.bot/cli 0.1.0-alpha.32 → 0.1.0-alpha.321

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 (308) hide show
  1. package/README.md +188 -190
  2. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +3 -2
  3. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +1 -1
  4. package/changelog.json +1924 -0
  5. package/dist/arc/attention-types.js +8 -0
  6. package/dist/arc/cares.js +140 -0
  7. package/dist/arc/episodes.js +117 -0
  8. package/dist/arc/intentions.js +133 -0
  9. package/dist/arc/json-store.js +117 -0
  10. package/dist/arc/obligations.js +237 -0
  11. package/dist/arc/packets.js +193 -0
  12. package/dist/arc/presence.js +185 -0
  13. package/dist/arc/task-lifecycle.js +65 -0
  14. package/dist/heart/active-work.js +832 -0
  15. package/dist/heart/agent-entry.js +37 -2
  16. package/dist/heart/attachments/image-normalize.js +194 -0
  17. package/dist/heart/attachments/materialize.js +97 -0
  18. package/dist/heart/attachments/originals.js +88 -0
  19. package/dist/heart/attachments/render.js +29 -0
  20. package/dist/heart/attachments/sources/adapter.js +2 -0
  21. package/dist/heart/attachments/sources/bluebubbles.js +156 -0
  22. package/dist/heart/attachments/sources/cli-local-file.js +78 -0
  23. package/dist/heart/attachments/sources/index.js +16 -0
  24. package/dist/heart/attachments/store.js +103 -0
  25. package/dist/heart/attachments/types.js +93 -0
  26. package/dist/heart/auth/auth-flow.js +456 -0
  27. package/dist/heart/bridges/manager.js +358 -0
  28. package/dist/heart/bridges/state-machine.js +135 -0
  29. package/dist/heart/bridges/store.js +123 -0
  30. package/dist/heart/bundle-state.js +168 -0
  31. package/dist/heart/commitments.js +111 -0
  32. package/dist/heart/config-registry.js +304 -0
  33. package/dist/heart/config.js +63 -30
  34. package/dist/heart/core.js +669 -195
  35. package/dist/heart/cross-chat-delivery.js +131 -0
  36. package/dist/heart/daemon/agent-config-check.js +149 -0
  37. package/dist/heart/daemon/agent-discovery.js +79 -3
  38. package/dist/heart/daemon/agent-service.js +360 -0
  39. package/dist/heart/daemon/agentic-repair.js +170 -0
  40. package/dist/heart/daemon/cadence.js +70 -0
  41. package/dist/heart/daemon/cli-defaults.js +596 -0
  42. package/dist/heart/daemon/cli-exec.js +2238 -0
  43. package/dist/heart/daemon/cli-help.js +306 -0
  44. package/dist/heart/daemon/cli-parse.js +824 -0
  45. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  46. package/dist/heart/daemon/cli-render.js +506 -0
  47. package/dist/heart/daemon/cli-types.js +8 -0
  48. package/dist/heart/daemon/daemon-cli.js +29 -1171
  49. package/dist/heart/daemon/daemon-entry.js +333 -3
  50. package/dist/heart/daemon/daemon-health.js +137 -0
  51. package/dist/heart/daemon/daemon-runtime-sync.js +153 -12
  52. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  53. package/dist/heart/daemon/daemon.js +751 -58
  54. package/dist/heart/daemon/doctor-types.js +8 -0
  55. package/dist/heart/daemon/doctor.js +322 -0
  56. package/dist/heart/daemon/health-monitor.js +66 -0
  57. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  58. package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
  59. package/dist/heart/daemon/http-health-probe.js +80 -0
  60. package/dist/heart/daemon/inner-status.js +89 -0
  61. package/dist/heart/daemon/interactive-repair.js +69 -0
  62. package/dist/heart/daemon/launchd.js +46 -9
  63. package/dist/heart/daemon/log-tailer.js +82 -12
  64. package/dist/heart/daemon/logs-prune.js +105 -0
  65. package/dist/heart/daemon/message-router.js +17 -8
  66. package/dist/heart/daemon/os-cron-deps.js +134 -0
  67. package/dist/heart/daemon/ouro-bot-entry.js +1 -1
  68. package/dist/heart/daemon/process-manager.js +201 -0
  69. package/dist/heart/daemon/provider-discovery.js +105 -0
  70. package/dist/heart/daemon/pulse.js +463 -0
  71. package/dist/heart/daemon/run-hooks.js +2 -0
  72. package/dist/heart/daemon/runtime-logging.js +67 -16
  73. package/dist/heart/daemon/runtime-metadata.js +101 -0
  74. package/dist/heart/daemon/runtime-mode.js +67 -0
  75. package/dist/heart/daemon/safe-mode.js +161 -0
  76. package/dist/heart/daemon/sense-manager.js +72 -3
  77. package/dist/heart/daemon/session-id-resolver.js +131 -0
  78. package/dist/heart/daemon/skill-management-installer.js +94 -0
  79. package/dist/heart/daemon/socket-client.js +307 -0
  80. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  81. package/dist/heart/daemon/startup-tui.js +227 -0
  82. package/dist/heart/daemon/task-scheduler.js +3 -25
  83. package/dist/heart/daemon/thoughts.js +510 -0
  84. package/dist/heart/daemon/up-progress.js +135 -0
  85. package/dist/heart/delegation.js +62 -0
  86. package/dist/heart/habits/habit-migration.js +181 -0
  87. package/dist/heart/habits/habit-parser.js +140 -0
  88. package/dist/heart/habits/habit-scheduler.js +371 -0
  89. package/dist/heart/{daemon → hatch}/hatch-flow.js +30 -120
  90. package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
  91. package/dist/heart/{daemon → hatch}/specialist-prompt.js +10 -7
  92. package/dist/heart/{daemon → hatch}/specialist-tools.js +49 -3
  93. package/dist/heart/identity.js +163 -60
  94. package/dist/heart/kicks.js +2 -20
  95. package/dist/heart/mcp/mcp-server.js +653 -0
  96. package/dist/heart/migrate-config.js +127 -0
  97. package/dist/heart/model-capabilities.js +59 -0
  98. package/dist/heart/outlook/outlook-http.js +439 -0
  99. package/dist/heart/outlook/outlook-read.js +28 -0
  100. package/dist/heart/outlook/outlook-render.js +1032 -0
  101. package/dist/heart/outlook/outlook-types.js +27 -0
  102. package/dist/heart/outlook/outlook-view.js +194 -0
  103. package/dist/heart/outlook/readers/agent-machine.js +355 -0
  104. package/dist/heart/outlook/readers/continuity-readers.js +332 -0
  105. package/dist/heart/outlook/readers/runtime-readers.js +660 -0
  106. package/dist/heart/outlook/readers/sessions.js +231 -0
  107. package/dist/heart/outlook/readers/shared.js +111 -0
  108. package/dist/heart/progress-story.js +42 -0
  109. package/dist/heart/provider-failover.js +88 -0
  110. package/dist/heart/provider-ping.js +162 -0
  111. package/dist/heart/providers/anthropic-token.js +163 -0
  112. package/dist/heart/providers/anthropic.js +169 -46
  113. package/dist/heart/providers/azure.js +98 -11
  114. package/dist/heart/providers/error-classification.js +63 -0
  115. package/dist/heart/providers/github-copilot.js +136 -0
  116. package/dist/heart/providers/minimax-vlm.js +189 -0
  117. package/dist/heart/providers/minimax.js +23 -5
  118. package/dist/heart/providers/openai-codex.js +33 -22
  119. package/dist/heart/session-activity.js +190 -0
  120. package/dist/heart/session-events.js +726 -0
  121. package/dist/heart/session-recall.js +162 -0
  122. package/dist/heart/start-of-turn-packet.js +341 -0
  123. package/dist/heart/streaming.js +36 -27
  124. package/dist/heart/sync.js +332 -0
  125. package/dist/heart/target-resolution.js +127 -0
  126. package/dist/heart/tempo.js +93 -0
  127. package/dist/heart/temporal-view.js +41 -0
  128. package/dist/heart/tool-activity-callbacks.js +36 -0
  129. package/dist/heart/tool-description.js +135 -0
  130. package/dist/heart/tool-friction.js +55 -0
  131. package/dist/heart/tool-loop.js +200 -0
  132. package/dist/heart/turn-context.js +358 -0
  133. package/dist/heart/turn-coordinator.js +28 -0
  134. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +1 -1
  135. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  136. package/dist/heart/{daemon → versioning}/ouro-path-installer.js +78 -35
  137. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  138. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  139. package/dist/heart/{daemon → versioning}/update-checker.js +12 -2
  140. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  141. package/dist/mind/associative-recall.js +137 -66
  142. package/dist/mind/bundle-manifest.js +8 -1
  143. package/dist/mind/context.js +89 -93
  144. package/dist/mind/diary-integrity.js +60 -0
  145. package/dist/mind/{memory.js → diary.js} +84 -96
  146. package/dist/mind/embedding-provider.js +60 -0
  147. package/dist/mind/file-state.js +179 -0
  148. package/dist/mind/first-impressions.js +14 -1
  149. package/dist/mind/friends/channel.js +56 -0
  150. package/dist/mind/friends/group-context.js +144 -0
  151. package/dist/mind/friends/resolver.js +37 -0
  152. package/dist/mind/friends/store-file.js +58 -3
  153. package/dist/mind/friends/trust-explanation.js +74 -0
  154. package/dist/mind/friends/types.js +8 -0
  155. package/dist/mind/journal-index.js +161 -0
  156. package/dist/mind/obligation-steering.js +221 -0
  157. package/dist/mind/pending.js +76 -9
  158. package/dist/mind/prompt.js +950 -113
  159. package/dist/mind/provenance-trust.js +26 -0
  160. package/dist/mind/scrutiny.js +173 -0
  161. package/dist/mind/token-estimate.js +8 -12
  162. package/dist/nerves/cli-logging.js +7 -1
  163. package/dist/nerves/coverage/audit.js +1 -1
  164. package/dist/nerves/coverage/file-completeness.js +76 -5
  165. package/dist/nerves/coverage/run-artifacts.js +1 -1
  166. package/dist/nerves/event-buffer.js +111 -0
  167. package/dist/nerves/index.js +224 -4
  168. package/dist/nerves/observation.js +20 -0
  169. package/dist/nerves/redact.js +79 -0
  170. package/dist/nerves/runtime.js +5 -1
  171. package/dist/outlook-ui/assets/index-IuR4F6y6.js +61 -0
  172. package/dist/outlook-ui/assets/index-LwChZTgL.css +1 -0
  173. package/dist/outlook-ui/index.html +15 -0
  174. package/dist/repertoire/ado-client.js +15 -56
  175. package/dist/repertoire/ado-semantic.js +11 -10
  176. package/dist/repertoire/api-client.js +97 -0
  177. package/dist/repertoire/bitwarden-store.js +319 -0
  178. package/dist/repertoire/bundle-templates.js +72 -0
  179. package/dist/repertoire/bw-installer.js +79 -0
  180. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  181. package/dist/repertoire/coding/context-pack.js +330 -0
  182. package/dist/repertoire/coding/feedback.js +197 -30
  183. package/dist/repertoire/coding/manager.js +159 -11
  184. package/dist/repertoire/coding/spawner.js +55 -9
  185. package/dist/repertoire/coding/tools.js +170 -7
  186. package/dist/repertoire/commerce-errors.js +109 -0
  187. package/dist/repertoire/commerce-self-test.js +156 -0
  188. package/dist/repertoire/credential-access.js +527 -0
  189. package/dist/repertoire/duffel-client.js +185 -0
  190. package/dist/repertoire/github-client.js +14 -55
  191. package/dist/repertoire/graph-client.js +11 -52
  192. package/dist/repertoire/guardrails.js +375 -0
  193. package/dist/repertoire/mcp-client.js +255 -0
  194. package/dist/repertoire/mcp-manager.js +305 -0
  195. package/dist/repertoire/mcp-tools.js +63 -0
  196. package/dist/repertoire/shell-sessions.js +133 -0
  197. package/dist/repertoire/skills.js +14 -23
  198. package/dist/repertoire/stripe-client.js +131 -0
  199. package/dist/repertoire/tasks/board.js +43 -5
  200. package/dist/repertoire/tasks/fix.js +182 -0
  201. package/dist/repertoire/tasks/index.js +28 -10
  202. package/dist/repertoire/tasks/lifecycle.js +2 -2
  203. package/dist/repertoire/tasks/parser.js +3 -2
  204. package/dist/repertoire/tasks/scanner.js +194 -37
  205. package/dist/repertoire/tasks/transitions.js +16 -79
  206. package/dist/repertoire/tool-results.js +29 -0
  207. package/dist/repertoire/tools-attachments.js +316 -0
  208. package/dist/repertoire/tools-base.js +45 -771
  209. package/dist/repertoire/tools-bluebubbles.js +1 -0
  210. package/dist/repertoire/tools-bridge.js +141 -0
  211. package/dist/repertoire/tools-bundle.js +984 -0
  212. package/dist/repertoire/tools-config.js +185 -0
  213. package/dist/repertoire/tools-continuity.js +248 -0
  214. package/dist/repertoire/tools-credential.js +182 -0
  215. package/dist/repertoire/tools-files.js +342 -0
  216. package/dist/repertoire/tools-flight.js +224 -0
  217. package/dist/repertoire/tools-flow.js +105 -0
  218. package/dist/repertoire/tools-github.js +1 -7
  219. package/dist/repertoire/tools-memory.js +376 -0
  220. package/dist/repertoire/tools-session.js +739 -0
  221. package/dist/repertoire/tools-shell.js +120 -0
  222. package/dist/repertoire/tools-stripe.js +180 -0
  223. package/dist/repertoire/tools-surface.js +243 -0
  224. package/dist/repertoire/tools-teams.js +12 -62
  225. package/dist/repertoire/tools-travel.js +125 -0
  226. package/dist/repertoire/tools-user-profile.js +144 -0
  227. package/dist/repertoire/tools-vault.js +110 -0
  228. package/dist/repertoire/tools.js +144 -138
  229. package/dist/repertoire/travel-api-client.js +360 -0
  230. package/dist/repertoire/user-profile.js +118 -0
  231. package/dist/repertoire/vault-setup.js +241 -0
  232. package/dist/scripts/claude-code-hook.js +41 -0
  233. package/dist/scripts/claude-code-stop-hook.js +47 -0
  234. package/dist/senses/attention-queue.js +116 -0
  235. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  236. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  237. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +143 -9
  238. package/dist/senses/bluebubbles/entry.js +13 -0
  239. package/dist/senses/bluebubbles/inbound-log.js +113 -0
  240. package/dist/senses/bluebubbles/index.js +1436 -0
  241. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  242. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +43 -12
  243. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +46 -6
  244. package/dist/senses/bluebubbles/replay.js +129 -0
  245. package/dist/senses/bluebubbles/runtime-state.js +109 -0
  246. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  247. package/dist/senses/cli/bracketed-paste.js +82 -0
  248. package/dist/senses/cli/image-paste.js +287 -0
  249. package/dist/senses/cli/image-ref-navigation.js +75 -0
  250. package/dist/senses/cli/ink-app.js +156 -0
  251. package/dist/senses/cli/inline-diff.js +64 -0
  252. package/dist/senses/cli/input-keys.js +174 -0
  253. package/dist/senses/cli/kill-ring.js +86 -0
  254. package/dist/senses/cli/message-list.js +51 -0
  255. package/dist/senses/cli/ouro-tui.js +605 -0
  256. package/dist/senses/cli/spinner-imperative.js +135 -0
  257. package/dist/senses/cli/spinner.js +101 -0
  258. package/dist/senses/cli/status-line.js +60 -0
  259. package/dist/senses/cli/streaming-markdown.js +526 -0
  260. package/dist/senses/cli/tool-display.js +83 -0
  261. package/dist/senses/cli/tool-render.js +85 -0
  262. package/dist/senses/cli/tui-store.js +240 -0
  263. package/dist/senses/cli/virtual-list.js +35 -0
  264. package/dist/senses/cli-entry.js +1 -1
  265. package/dist/senses/cli-layout.js +187 -0
  266. package/dist/senses/cli.js +595 -246
  267. package/dist/senses/commands.js +65 -1
  268. package/dist/senses/continuity.js +94 -0
  269. package/dist/senses/habit-turn-message.js +108 -0
  270. package/dist/senses/inner-dialog-worker.js +112 -19
  271. package/dist/senses/inner-dialog.js +633 -86
  272. package/dist/senses/pipeline.js +565 -0
  273. package/dist/senses/shared-turn.js +199 -0
  274. package/dist/senses/surface-tool.js +68 -0
  275. package/dist/senses/teams.js +666 -166
  276. package/dist/senses/trust-gate.js +112 -2
  277. package/package.json +27 -7
  278. package/skills/agent-commerce.md +106 -0
  279. package/skills/browser-navigation.md +110 -0
  280. package/skills/commerce-setup-guide.md +116 -0
  281. package/skills/commerce-setup.md +84 -0
  282. package/skills/configure-dev-tools.md +81 -0
  283. package/skills/travel-planning.md +138 -0
  284. package/dist/heart/daemon/subagent-installer.js +0 -134
  285. package/dist/senses/bluebubbles-entry.js +0 -11
  286. package/dist/senses/bluebubbles.js +0 -544
  287. package/dist/senses/debug-activity.js +0 -108
  288. package/subagents/README.md +0 -73
  289. package/subagents/work-doer.md +0 -235
  290. package/subagents/work-merger.md +0 -618
  291. package/subagents/work-planner.md +0 -382
  292. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  293. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  294. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  295. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  296. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  297. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  298. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  299. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  300. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  301. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  302. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  303. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +0 -0
  304. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  305. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  306. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  307. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  308. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
@@ -35,6 +35,7 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
36
  exports.getSpecialistTools = getSpecialistTools;
37
37
  exports.createSpecialistExecTool = createSpecialistExecTool;
38
+ const crypto = __importStar(require("crypto"));
38
39
  const fs = __importStar(require("fs"));
39
40
  const path = __importStar(require("path"));
40
41
  const tools_base_1 = require("../../repertoire/tools-base");
@@ -58,6 +59,14 @@ const completeAdoptionTool = {
58
59
  type: "string",
59
60
  description: "a warm handoff message to display to the human after the agent is hatched",
60
61
  },
62
+ phone: {
63
+ type: "string",
64
+ description: "the human's phone number (optional, for iMessage contact recognition)",
65
+ },
66
+ teams_handle: {
67
+ type: "string",
68
+ description: "the human's Teams email/handle (optional, for Teams contact recognition)",
69
+ },
61
70
  },
62
71
  required: ["name", "handoff_message"],
63
72
  },
@@ -65,12 +74,23 @@ const completeAdoptionTool = {
65
74
  };
66
75
  const readFileTool = tools_base_1.baseToolDefinitions.find((d) => d.tool.function.name === "read_file");
67
76
  const writeFileTool = tools_base_1.baseToolDefinitions.find((d) => d.tool.function.name === "write_file");
68
- const listDirTool = tools_base_1.baseToolDefinitions.find((d) => d.tool.function.name === "list_directory");
77
+ const listDirToolSchema = {
78
+ type: "function",
79
+ function: {
80
+ name: "list_directory",
81
+ description: "list directory contents",
82
+ parameters: {
83
+ type: "object",
84
+ properties: { path: { type: "string" } },
85
+ required: ["path"],
86
+ },
87
+ },
88
+ };
69
89
  /**
70
90
  * Returns the specialist's tool schema array.
71
91
  */
72
92
  function getSpecialistTools() {
73
- return [completeAdoptionTool, tools_base_1.finalAnswerTool, readFileTool.tool, writeFileTool.tool, listDirTool.tool];
93
+ return [completeAdoptionTool, tools_base_1.settleTool, readFileTool.tool, writeFileTool.tool, listDirToolSchema];
74
94
  }
75
95
  const PSYCHE_FILES = ["SOUL.md", "IDENTITY.md", "LORE.md", "TACIT.md", "ASPIRATIONS.md"];
76
96
  function isPascalCase(name) {
@@ -90,8 +110,8 @@ function scaffoldBundle(bundleRoot) {
90
110
  writeReadme(path.join(bundleRoot, "memory", "archive"), "Archived memory.");
91
111
  writeReadme(path.join(bundleRoot, "friends"), "Known friend records.");
92
112
  writeReadme(path.join(bundleRoot, "tasks"), "Task files.");
93
- writeReadme(path.join(bundleRoot, "tasks", "habits"), "Recurring tasks.");
94
113
  writeReadme(path.join(bundleRoot, "tasks", "one-shots"), "One-shot tasks.");
114
+ writeReadme(path.join(bundleRoot, "habits"), "Recurring habits and autonomous rhythms.");
95
115
  writeReadme(path.join(bundleRoot, "tasks", "ongoing"), "Ongoing tasks.");
96
116
  writeReadme(path.join(bundleRoot, "skills"), "Local skill files.");
97
117
  writeReadme(path.join(bundleRoot, "senses"), "Sense-specific config.");
@@ -164,6 +184,32 @@ async function execCompleteAdoption(args, deps) {
164
184
  }
165
185
  return `error: failed to write secrets: ${e instanceof Error ? e.message : /* v8 ignore next -- defensive: non-Error catch branch @preserve */ String(e)}`;
166
186
  }
187
+ // Create initial friend record if contact info provided
188
+ const phone = args.phone;
189
+ const teamsHandle = args.teams_handle;
190
+ if (phone || teamsHandle) {
191
+ const friendId = crypto.randomUUID();
192
+ const now = new Date().toISOString();
193
+ const externalIds = [];
194
+ if (phone)
195
+ externalIds.push({ provider: "imessage-handle", externalId: phone, linkedAt: now });
196
+ if (teamsHandle)
197
+ externalIds.push({ provider: "aad", externalId: teamsHandle, linkedAt: now });
198
+ const friendRecord = {
199
+ id: friendId,
200
+ name: deps.humanName ?? "primary",
201
+ trustLevel: "family",
202
+ externalIds,
203
+ tenantMemberships: [],
204
+ toolPreferences: {},
205
+ notes: {},
206
+ createdAt: now,
207
+ updatedAt: now,
208
+ schemaVersion: 1,
209
+ };
210
+ const friendPath = path.join(targetBundle, "friends", `${friendId}.json`);
211
+ fs.writeFileSync(friendPath, JSON.stringify(friendRecord, null, 2), "utf-8");
212
+ }
167
213
  // Play hatch animation
168
214
  await (0, hatch_animation_1.playHatchAnimation)(name, deps.animationWriter);
169
215
  // Display handoff message
@@ -33,12 +33,21 @@ 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.resolveVaultConfig = resolveVaultConfig;
38
+ exports.normalizeSenses = normalizeSenses;
37
39
  exports.buildDefaultAgentTemplate = buildDefaultAgentTemplate;
38
40
  exports.getAgentName = getAgentName;
39
41
  exports.getRepoRoot = getRepoRoot;
40
42
  exports.getAgentBundlesRoot = getAgentBundlesRoot;
41
43
  exports.getAgentRoot = getAgentRoot;
44
+ exports.getAgentStateRoot = getAgentStateRoot;
45
+ exports.getAgentRepoWorkspacesRoot = getAgentRepoWorkspacesRoot;
46
+ exports.getAgentDaemonStateRoot = getAgentDaemonStateRoot;
47
+ exports.getAgentDaemonLogsDir = getAgentDaemonLogsDir;
48
+ exports.getAgentDaemonLoggingConfigPath = getAgentDaemonLoggingConfigPath;
49
+ exports.getAgentMessagesRoot = getAgentMessagesRoot;
50
+ exports.getAgentToolsRoot = getAgentToolsRoot;
42
51
  exports.getAgentSecretsPath = getAgentSecretsPath;
43
52
  exports.loadAgentConfig = loadAgentConfig;
44
53
  exports.setAgentName = setAgentName;
@@ -49,6 +58,15 @@ const fs = __importStar(require("fs"));
49
58
  const os = __importStar(require("os"));
50
59
  const path = __importStar(require("path"));
51
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
+ };
52
70
  exports.DEFAULT_AGENT_CONTEXT = {
53
71
  maxTokens: 80000,
54
72
  contextMargin: 20,
@@ -58,6 +76,17 @@ exports.DEFAULT_AGENT_PHRASES = {
58
76
  tool: ["running tool"],
59
77
  followup: ["processing"],
60
78
  };
79
+ exports.DEFAULT_VAULT_SERVER_URL = "https://vault.ouro.bot";
80
+ /**
81
+ * Resolve the vault config for an agent, applying defaults.
82
+ * If vault is not configured in agent.json, returns default values.
83
+ */
84
+ function resolveVaultConfig(agentName, config) {
85
+ return {
86
+ email: config?.email ?? `${agentName}@ouro.bot`,
87
+ serverUrl: config?.serverUrl ?? exports.DEFAULT_VAULT_SERVER_URL,
88
+ };
89
+ }
61
90
  exports.DEFAULT_AGENT_SENSES = {
62
91
  cli: { enabled: true },
63
92
  teams: { enabled: false },
@@ -116,9 +145,10 @@ function normalizeSenses(value, configFile) {
116
145
  }
117
146
  function buildDefaultAgentTemplate(_agentName) {
118
147
  return {
119
- version: 1,
148
+ version: 2,
120
149
  enabled: true,
121
- provider: "anthropic",
150
+ humanFacing: { provider: "anthropic", model: "claude-opus-4-6" },
151
+ agentFacing: { provider: "anthropic", model: "claude-opus-4-6" },
122
152
  context: { ...exports.DEFAULT_AGENT_CONTEXT },
123
153
  senses: {
124
154
  cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
@@ -133,7 +163,6 @@ function buildDefaultAgentTemplate(_agentName) {
133
163
  };
134
164
  }
135
165
  let _cachedAgentName = null;
136
- let _cachedAgentConfig = null;
137
166
  let _agentConfigOverride = null;
138
167
  /**
139
168
  * Parse `--agent <name>` from process.argv.
@@ -175,13 +204,49 @@ function getRepoRoot() {
175
204
  * Returns the shared bundle root directory: `~/AgentBundles/`
176
205
  */
177
206
  function getAgentBundlesRoot() {
178
- return path.join(os.homedir(), "AgentBundles");
207
+ const homeBase = process.env.WEBSITE_SITE_NAME ? "/home" : os.homedir();
208
+ return path.join(homeBase, "AgentBundles");
179
209
  }
180
210
  /**
181
211
  * Returns the agent-specific bundle directory: `~/AgentBundles/<agentName>.ouro/`
182
212
  */
183
- function getAgentRoot() {
184
- return path.join(getAgentBundlesRoot(), `${getAgentName()}.ouro`);
213
+ function getAgentRoot(agentName = getAgentName()) {
214
+ return path.join(getAgentBundlesRoot(), `${agentName}.ouro`);
215
+ }
216
+ function resolveOptionalAgentName(agentName) {
217
+ if (agentName && agentName.trim().length > 0)
218
+ return agentName.trim();
219
+ try {
220
+ return getAgentName();
221
+ }
222
+ catch {
223
+ return "slugger";
224
+ }
225
+ }
226
+ /**
227
+ * Returns the bundle-local runtime state directory: `~/AgentBundles/<agentName>.ouro/state/`
228
+ */
229
+ function getAgentStateRoot(agentName) {
230
+ return path.join(getAgentRoot(resolveOptionalAgentName(agentName)), "state");
231
+ }
232
+ exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/ouroborosbot/ouroboros.git";
233
+ function getAgentRepoWorkspacesRoot(agentName) {
234
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "workspaces");
235
+ }
236
+ function getAgentDaemonStateRoot(agentName) {
237
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "daemon");
238
+ }
239
+ function getAgentDaemonLogsDir(agentName) {
240
+ return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logs");
241
+ }
242
+ function getAgentDaemonLoggingConfigPath(agentName) {
243
+ return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logging.json");
244
+ }
245
+ function getAgentMessagesRoot(agentName) {
246
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "messages");
247
+ }
248
+ function getAgentToolsRoot(agentName) {
249
+ return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "tools");
185
250
  }
186
251
  /**
187
252
  * Returns the conventional secrets path: `~/.agentsecrets/<agentName>/secrets.json`
@@ -189,26 +254,11 @@ function getAgentRoot() {
189
254
  function getAgentSecretsPath(agentName = getAgentName()) {
190
255
  return path.join(os.homedir(), ".agentsecrets", agentName, "secrets.json");
191
256
  }
192
- /**
193
- * Load and parse `<agentRoot>/agent.json`.
194
- * Caches the result after first load.
195
- * Throws descriptive error if file is missing or contains invalid JSON.
196
- */
197
- function loadAgentConfig() {
198
- if (_agentConfigOverride) {
199
- return _agentConfigOverride;
200
- }
201
- if (_cachedAgentConfig) {
202
- (0, runtime_1.emitNervesEvent)({
203
- event: "identity.resolve",
204
- component: "config/identity",
205
- message: "loaded agent config from cache",
206
- meta: { source: "cache" },
207
- });
208
- return _cachedAgentConfig;
209
- }
210
- const agentRoot = getAgentRoot();
211
- const configFile = path.join(agentRoot, "agent.json");
257
+ const VALID_PROVIDERS = ["azure", "minimax", "anthropic", "openai-codex", "github-copilot"];
258
+ function isValidProvider(value) {
259
+ return typeof value === "string" && VALID_PROVIDERS.includes(value);
260
+ }
261
+ function readAndParseAgentJson(configFile) {
212
262
  let raw;
213
263
  try {
214
264
  raw = fs.readFileSync(configFile, "utf-8");
@@ -226,9 +276,8 @@ function loadAgentConfig() {
226
276
  });
227
277
  throw new Error(`Cannot read agent.json at ${configFile}. Does the agent directory exist?`);
228
278
  }
229
- let parsed;
230
279
  try {
231
- parsed = JSON.parse(raw);
280
+ return JSON.parse(raw);
232
281
  }
233
282
  catch (error) {
234
283
  (0, runtime_1.emitNervesEvent)({
@@ -243,6 +292,62 @@ function loadAgentConfig() {
243
292
  });
244
293
  throw new Error(`Invalid JSON in agent.json at ${configFile}. Check syntax.`);
245
294
  }
295
+ }
296
+ function validateFacingConfig(parsed, facingName, configFile) {
297
+ const raw = parsed[facingName];
298
+ if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
299
+ (0, runtime_1.emitNervesEvent)({
300
+ level: "error",
301
+ event: "config_identity.error",
302
+ component: "config/identity",
303
+ message: `agent config missing or invalid ${facingName}`,
304
+ meta: { path: configFile, [facingName]: raw ?? null },
305
+ });
306
+ throw new Error(`agent.json at ${configFile} must include ${facingName} as { provider, model }.`);
307
+ }
308
+ const facing = raw;
309
+ if (!isValidProvider(facing.provider)) {
310
+ (0, runtime_1.emitNervesEvent)({
311
+ level: "error",
312
+ event: "config_identity.error",
313
+ component: "config/identity",
314
+ message: `agent config has invalid provider in ${facingName}`,
315
+ meta: { path: configFile, provider: facing.provider ?? null },
316
+ });
317
+ throw new Error(`agent.json at ${configFile} ${facingName}.provider must be one of: ${VALID_PROVIDERS.join(", ")}.`);
318
+ }
319
+ if (typeof facing.model !== "string") {
320
+ (0, runtime_1.emitNervesEvent)({
321
+ level: "error",
322
+ event: "config_identity.error",
323
+ component: "config/identity",
324
+ message: `agent config has invalid model in ${facingName}`,
325
+ meta: { path: configFile, model: facing.model ?? null },
326
+ });
327
+ throw new Error(`agent.json at ${configFile} ${facingName}.model must be a string.`);
328
+ }
329
+ return { provider: facing.provider, model: facing.model };
330
+ }
331
+ /**
332
+ * Load and parse `<agentRoot>/agent.json`.
333
+ * Reads the file fresh on each call unless an override is set.
334
+ * If the config is v1, auto-migrates to v2 via migrateAgentConfigV1ToV2 and re-reads.
335
+ * Throws descriptive error if file is missing or contains invalid JSON.
336
+ */
337
+ function loadAgentConfig() {
338
+ if (_agentConfigOverride) {
339
+ return _agentConfigOverride;
340
+ }
341
+ const agentRoot = getAgentRoot();
342
+ const configFile = path.join(agentRoot, "agent.json");
343
+ let parsed = readAndParseAgentJson(configFile);
344
+ // Inline migration: v1 -> v2
345
+ const rawVersion = parsed.version;
346
+ const initialVersion = typeof rawVersion === "number" ? rawVersion : 1;
347
+ if (initialVersion < 2) {
348
+ (0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
349
+ parsed = readAndParseAgentJson(configFile);
350
+ }
246
351
  const existingPhrases = parsed.phrases;
247
352
  const needsFill = !existingPhrases ||
248
353
  !existingPhrases.thinking ||
@@ -264,27 +369,11 @@ function loadAgentConfig() {
264
369
  });
265
370
  fs.writeFileSync(configFile, JSON.stringify(parsed, null, 2) + "\n", "utf-8");
266
371
  }
267
- const rawProvider = parsed.provider;
268
- if (rawProvider !== "azure" &&
269
- rawProvider !== "minimax" &&
270
- rawProvider !== "anthropic" &&
271
- rawProvider !== "openai-codex") {
272
- (0, runtime_1.emitNervesEvent)({
273
- level: "error",
274
- event: "config_identity.error",
275
- component: "config/identity",
276
- message: "agent config missing or invalid provider",
277
- meta: {
278
- path: configFile,
279
- provider: rawProvider,
280
- },
281
- });
282
- throw new Error(`agent.json at ${configFile} must include provider: "azure", "minimax", "anthropic", or "openai-codex".`);
283
- }
284
- const rawVersion = parsed.version;
285
- const version = rawVersion === undefined ? 1 : rawVersion;
286
- if (typeof version !== "number" ||
287
- !Number.isInteger(version) ||
372
+ // Validate v2 facing configs
373
+ const humanFacing = validateFacingConfig(parsed, "humanFacing", configFile);
374
+ const agentFacing = validateFacingConfig(parsed, "agentFacing", configFile);
375
+ const version = typeof parsed.version === "number" ? parsed.version : 1;
376
+ if (!Number.isInteger(version) ||
288
377
  version < 1) {
289
378
  (0, runtime_1.emitNervesEvent)({
290
379
  level: "error",
@@ -293,7 +382,7 @@ function loadAgentConfig() {
293
382
  message: "agent config missing or invalid version",
294
383
  meta: {
295
384
  path: configFile,
296
- version: rawVersion,
385
+ version: parsed.version,
297
386
  },
298
387
  });
299
388
  throw new Error(`agent.json at ${configFile} must include version as integer >= 1.`);
@@ -313,22 +402,37 @@ function loadAgentConfig() {
313
402
  });
314
403
  throw new Error(`agent.json at ${configFile} must include enabled as boolean.`);
315
404
  }
316
- _cachedAgentConfig = {
405
+ // Tolerate deprecated provider field for backward compatibility
406
+ const rawProvider = parsed.provider;
407
+ const provider = isValidProvider(rawProvider) ? rawProvider : undefined;
408
+ // Spread parsed first so any field present in AgentConfig is carried
409
+ // through by default, then explicitly override the fields that need
410
+ // validation or normalization. This eliminates the field-drop bug class
411
+ // that caused the `sync` block (and previously `shell`) to be silently
412
+ // omitted from the returned config. Regression-guarded by the
413
+ // Required<AgentConfig> contract test in identity-contract.test.ts.
414
+ const config = {
415
+ ...parsed,
317
416
  version,
318
417
  enabled,
319
- provider: rawProvider,
320
- context: parsed.context,
321
- logging: parsed.logging,
418
+ humanFacing,
419
+ agentFacing,
322
420
  senses: normalizeSenses(parsed.senses, configFile),
323
421
  phrases: parsed.phrases,
324
422
  };
423
+ if (provider !== undefined) {
424
+ config.provider = provider;
425
+ }
426
+ else {
427
+ delete config.provider;
428
+ }
325
429
  (0, runtime_1.emitNervesEvent)({
326
430
  event: "identity.resolve",
327
431
  component: "config/identity",
328
432
  message: "loaded agent config from disk",
329
433
  meta: { source: "disk" },
330
434
  });
331
- return _cachedAgentConfig;
435
+ return config;
332
436
  }
333
437
  /**
334
438
  * Prime the agent name cache explicitly.
@@ -348,11 +452,11 @@ function setAgentConfigOverride(config) {
348
452
  _agentConfigOverride = config;
349
453
  }
350
454
  /**
351
- * Clear only the cached agent config while preserving the resolved agent identity.
352
- * Used when a running agent should pick up updated disk-backed config on the next turn.
455
+ * Preserve the compatibility hook for callers that previously cleared cached
456
+ * disk-backed agent config. Agent config is now read fresh on every call.
353
457
  */
354
458
  function resetAgentConfigCache() {
355
- _cachedAgentConfig = null;
459
+ // No-op: disk-backed agent config is no longer memoized in-process.
356
460
  }
357
461
  /**
358
462
  * Clear all cached identity state.
@@ -360,6 +464,5 @@ function resetAgentConfigCache() {
360
464
  */
361
465
  function resetIdentity() {
362
466
  _cachedAgentName = null;
363
- _cachedAgentConfig = null;
364
467
  _agentConfigOverride = null;
365
468
  }
@@ -1,28 +1,11 @@
1
1
  "use strict";
2
- // TODO: Kicks enforce "any action" but not "meaningful action". After a narration
3
- // kick, the model can satisfy the constraint by calling a no-op tool like
4
- // get_current_time({}). We need to detect trivial compliance and either re-kick
5
- // or discount the tool call. Ideally, the kick message would suggest a specific
6
- // tool call based on conversation context (what the user asked, what tools are
7
- // relevant) rather than just saying "call a tool". That's a bigger piece of work —
8
- // it requires the kick system to be context-aware.
9
- // See ouroboros' observation: "i'm not chickening out. i'm satisfying a crude
10
- // constraint. poorly."
11
- //
12
- // A kick is a self-correction. When the harness detects a malformed response,
13
- // it injects an assistant-role message as if the model caught its own mistake.
14
- //
15
- // Kicks are:
16
- // - assistant role (self-correction, not external rebuke)
17
- // - first person ("I" not "you")
18
- // - forward-looking (what I'm doing next, not what I did wrong)
19
- // - short (one sentence)
20
2
  Object.defineProperty(exports, "__esModule", { value: true });
21
3
  exports.hasToolIntent = hasToolIntent;
22
4
  exports.detectKick = detectKick;
5
+ const runtime_1 = require("../nerves/runtime");
23
6
  const KICK_MESSAGES = {
24
7
  empty: "I sent an empty message by accident — let me try again.",
25
- narration: "I narrated instead of acting. Using the tool now -- if done, calling final_answer.",
8
+ narration: "I narrated instead of acting. Using the tool now -- if done, calling settle.",
26
9
  tool_required: "tool-required is on — I need to call a tool. use /tool-required to turn it off.",
27
10
  };
28
11
  const TOOL_INTENT_PATTERNS = [
@@ -141,4 +124,3 @@ function detectKick(content, options) {
141
124
  }
142
125
  return null;
143
126
  }
144
- const runtime_1 = require("../nerves/runtime");