@ouro.bot/cli 0.1.0-alpha.5 → 0.1.0-alpha.500

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