@ouro.bot/cli 0.1.0-alpha.52 → 0.1.0-alpha.520

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 (375) hide show
  1. package/README.md +133 -19
  2. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +4 -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 +3353 -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 +837 -26
  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 +427 -0
  28. package/dist/heart/background-operations.js +281 -0
  29. package/dist/heart/bundle-state.js +168 -0
  30. package/dist/heart/commitments.js +111 -0
  31. package/dist/heart/config-registry.js +304 -0
  32. package/dist/heart/config.js +119 -129
  33. package/dist/heart/core.js +948 -243
  34. package/dist/heart/cross-chat-delivery.js +3 -18
  35. package/dist/heart/daemon/agent-config-check.js +512 -0
  36. package/dist/heart/daemon/agent-discovery.js +102 -3
  37. package/dist/heart/daemon/agent-service.js +360 -0
  38. package/dist/heart/daemon/agentic-repair.js +554 -0
  39. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  40. package/dist/heart/daemon/boot-sync-probe.js +197 -0
  41. package/dist/heart/daemon/cadence.js +70 -0
  42. package/dist/heart/daemon/cli-defaults.js +643 -0
  43. package/dist/heart/daemon/cli-exec.js +7476 -0
  44. package/dist/heart/daemon/cli-help.js +493 -0
  45. package/dist/heart/daemon/cli-parse.js +1557 -0
  46. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  47. package/dist/heart/daemon/cli-render.js +649 -0
  48. package/dist/heart/daemon/cli-types.js +8 -0
  49. package/dist/heart/daemon/connect-bay.js +323 -0
  50. package/dist/heart/daemon/daemon-cli.js +29 -1631
  51. package/dist/heart/daemon/daemon-entry.js +404 -3
  52. package/dist/heart/daemon/daemon-health.js +183 -0
  53. package/dist/heart/daemon/daemon-rollup.js +58 -0
  54. package/dist/heart/daemon/daemon-runtime-sync.js +190 -12
  55. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  56. package/dist/heart/daemon/daemon.js +758 -60
  57. package/dist/heart/daemon/dns-workflow.js +394 -0
  58. package/dist/heart/daemon/doctor-types.js +8 -0
  59. package/dist/heart/daemon/doctor.js +837 -0
  60. package/dist/heart/daemon/drift-detection.js +146 -0
  61. package/dist/heart/daemon/health-monitor.js +92 -1
  62. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  63. package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
  64. package/dist/heart/daemon/http-health-probe.js +80 -0
  65. package/dist/heart/daemon/human-command-screens.js +234 -0
  66. package/dist/heart/daemon/human-readiness.js +114 -0
  67. package/dist/heart/daemon/inner-status.js +102 -0
  68. package/dist/heart/daemon/interactive-repair.js +394 -0
  69. package/dist/heart/daemon/launchd.js +25 -5
  70. package/dist/heart/daemon/log-tailer.js +82 -12
  71. package/dist/heart/daemon/logs-prune.js +110 -0
  72. package/dist/heart/daemon/message-router.js +2 -2
  73. package/dist/heart/daemon/os-cron-deps.js +134 -0
  74. package/dist/heart/daemon/ouro-bot-entry.js +4 -2
  75. package/dist/heart/daemon/ouro-entry.js +3 -1
  76. package/dist/heart/daemon/process-manager.js +381 -26
  77. package/dist/heart/daemon/provider-discovery.js +137 -0
  78. package/dist/heart/daemon/provider-ping-progress.js +83 -0
  79. package/dist/heart/daemon/pulse.js +475 -0
  80. package/dist/heart/daemon/readiness-repair.js +365 -0
  81. package/dist/heart/daemon/run-hooks.js +2 -0
  82. package/dist/heart/daemon/runtime-logging.js +67 -16
  83. package/dist/heart/daemon/runtime-metadata.js +73 -0
  84. package/dist/heart/daemon/runtime-mode.js +67 -0
  85. package/dist/heart/daemon/safe-mode.js +161 -0
  86. package/dist/heart/daemon/sense-manager.js +259 -37
  87. package/dist/heart/daemon/session-id-resolver.js +131 -0
  88. package/dist/heart/daemon/skill-management-installer.js +94 -0
  89. package/dist/heart/daemon/socket-client.js +109 -4
  90. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  91. package/dist/heart/daemon/startup-tui.js +330 -0
  92. package/dist/heart/daemon/task-scheduler.js +3 -25
  93. package/dist/heart/daemon/terminal-ui.js +499 -0
  94. package/dist/heart/daemon/thoughts.js +162 -17
  95. package/dist/heart/daemon/up-progress.js +366 -0
  96. package/dist/heart/daemon/vault-items.js +56 -0
  97. package/dist/heart/delegation.js +1 -1
  98. package/dist/heart/habits/habit-migration.js +189 -0
  99. package/dist/heart/habits/habit-parser.js +140 -0
  100. package/dist/heart/habits/habit-runtime-state.js +100 -0
  101. package/dist/heart/habits/habit-scheduler.js +372 -0
  102. package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
  103. package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
  104. package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
  105. package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
  106. package/dist/heart/identity.js +205 -66
  107. package/dist/heart/kept-notes.js +357 -0
  108. package/dist/heart/kicks.js +1 -1
  109. package/dist/heart/machine-identity.js +161 -0
  110. package/dist/heart/mail-import-discovery.js +353 -0
  111. package/dist/heart/mcp/mcp-server.js +653 -0
  112. package/dist/heart/migrate-config.js +100 -0
  113. package/dist/heart/model-capabilities.js +19 -0
  114. package/dist/heart/outlook/outlook-http-hooks.js +66 -0
  115. package/dist/heart/outlook/outlook-http-response.js +7 -0
  116. package/dist/heart/outlook/outlook-http-routes.js +244 -0
  117. package/dist/heart/outlook/outlook-http-static.js +103 -0
  118. package/dist/heart/outlook/outlook-http-transport.js +116 -0
  119. package/dist/heart/outlook/outlook-http.js +99 -0
  120. package/dist/heart/outlook/outlook-read.js +31 -0
  121. package/dist/heart/outlook/outlook-types.js +27 -0
  122. package/dist/heart/outlook/outlook-view.js +195 -0
  123. package/dist/heart/outlook/readers/agent-machine.js +382 -0
  124. package/dist/heart/outlook/readers/continuity-readers.js +336 -0
  125. package/dist/heart/outlook/readers/mail.js +362 -0
  126. package/dist/heart/outlook/readers/runtime-readers.js +650 -0
  127. package/dist/heart/outlook/readers/sessions.js +232 -0
  128. package/dist/heart/outlook/readers/shared.js +111 -0
  129. package/dist/heart/platform.js +81 -0
  130. package/dist/heart/provider-attempt.js +134 -0
  131. package/dist/heart/provider-binding-resolver.js +255 -0
  132. package/dist/heart/provider-credentials.js +425 -0
  133. package/dist/heart/provider-failover.js +301 -0
  134. package/dist/heart/provider-models.js +81 -0
  135. package/dist/heart/provider-ping.js +262 -0
  136. package/dist/heart/provider-state.js +216 -0
  137. package/dist/heart/provider-visibility.js +188 -0
  138. package/dist/heart/providers/anthropic-token.js +131 -0
  139. package/dist/heart/providers/anthropic.js +139 -52
  140. package/dist/heart/providers/azure.js +97 -13
  141. package/dist/heart/providers/error-classification.js +127 -0
  142. package/dist/heart/providers/github-copilot.js +145 -0
  143. package/dist/heart/providers/minimax-vlm.js +189 -0
  144. package/dist/heart/providers/minimax.js +26 -8
  145. package/dist/heart/providers/openai-codex.js +55 -40
  146. package/dist/heart/runtime-capability-check.js +170 -0
  147. package/dist/heart/runtime-credentials.js +367 -0
  148. package/dist/heart/sense-truth.js +11 -4
  149. package/dist/heart/session-activity.js +43 -22
  150. package/dist/heart/session-events.js +1149 -0
  151. package/dist/heart/session-playback-cli-main.js +5 -0
  152. package/dist/heart/session-playback-cli.js +36 -0
  153. package/dist/heart/session-playback.js +231 -0
  154. package/dist/heart/session-stats-cli-main.js +5 -0
  155. package/dist/heart/session-stats.js +182 -0
  156. package/dist/heart/session-transcript.js +243 -0
  157. package/dist/heart/start-of-turn-packet.js +345 -0
  158. package/dist/heart/streaming.js +44 -27
  159. package/dist/heart/sync-classification.js +176 -0
  160. package/dist/heart/sync.js +449 -0
  161. package/dist/heart/target-resolution.js +9 -5
  162. package/dist/heart/tempo.js +93 -0
  163. package/dist/heart/temporal-view.js +41 -0
  164. package/dist/heart/timeouts.js +101 -0
  165. package/dist/heart/tool-activity-callbacks.js +36 -0
  166. package/dist/heart/tool-description.js +139 -0
  167. package/dist/heart/tool-friction.js +55 -0
  168. package/dist/heart/tool-loop.js +200 -0
  169. package/dist/heart/turn-context.js +381 -0
  170. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +1 -1
  171. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  172. package/dist/heart/versioning/ouro-path-installer.js +425 -0
  173. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  174. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  175. package/dist/heart/{daemon → versioning}/update-checker.js +5 -1
  176. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  177. package/dist/mailroom/attention.js +167 -0
  178. package/dist/mailroom/autonomy.js +209 -0
  179. package/dist/mailroom/blob-store.js +606 -0
  180. package/dist/mailroom/body-cache.js +61 -0
  181. package/dist/mailroom/core.js +672 -0
  182. package/dist/mailroom/entry.js +160 -0
  183. package/dist/mailroom/file-store.js +426 -0
  184. package/dist/mailroom/mbox-import.js +382 -0
  185. package/dist/mailroom/outbound.js +380 -0
  186. package/dist/mailroom/policy.js +263 -0
  187. package/dist/mailroom/reader.js +228 -0
  188. package/dist/mailroom/search-cache.js +182 -0
  189. package/dist/mailroom/search-relevance.js +319 -0
  190. package/dist/mailroom/smtp-ingress.js +176 -0
  191. package/dist/mailroom/source-state.js +176 -0
  192. package/dist/mailroom/thread.js +109 -0
  193. package/dist/mailroom/travel-extract.js +89 -0
  194. package/dist/mind/bundle-manifest.js +7 -1
  195. package/dist/mind/context.js +165 -101
  196. package/dist/mind/diary-integrity.js +60 -0
  197. package/dist/mind/{memory.js → diary.js} +74 -93
  198. package/dist/mind/embedding-provider.js +60 -0
  199. package/dist/mind/file-state.js +179 -0
  200. package/dist/mind/friends/channel.js +30 -0
  201. package/dist/mind/friends/resolver.js +54 -2
  202. package/dist/mind/friends/store-file.js +39 -3
  203. package/dist/mind/friends/types.js +2 -2
  204. package/dist/mind/journal-index.js +161 -0
  205. package/dist/mind/note-search.js +268 -0
  206. package/dist/mind/obligation-steering.js +221 -0
  207. package/dist/mind/pending.js +4 -0
  208. package/dist/mind/prompt-refresh.js +3 -2
  209. package/dist/mind/prompt.js +942 -122
  210. package/dist/mind/provenance-trust.js +26 -0
  211. package/dist/mind/scrutiny.js +173 -0
  212. package/dist/nerves/cli-logging.js +7 -1
  213. package/dist/nerves/coverage/audit-rules.js +15 -6
  214. package/dist/nerves/coverage/audit.js +28 -2
  215. package/dist/nerves/coverage/cli.js +1 -1
  216. package/dist/nerves/coverage/contract.js +5 -5
  217. package/dist/nerves/coverage/file-completeness.js +139 -5
  218. package/dist/nerves/coverage/run-artifacts.js +1 -1
  219. package/dist/nerves/event-buffer.js +111 -0
  220. package/dist/nerves/index.js +224 -4
  221. package/dist/nerves/observation.js +20 -0
  222. package/dist/nerves/redact.js +79 -0
  223. package/dist/nerves/review/cli-main.js +5 -0
  224. package/dist/nerves/review/cli.js +156 -0
  225. package/dist/nerves/review/core.js +152 -0
  226. package/dist/nerves/runtime.js +5 -1
  227. package/dist/outlook-ui/assets/index-BPr5vNuM.css +1 -0
  228. package/dist/outlook-ui/assets/index-Cm51CY9W.js +61 -0
  229. package/dist/outlook-ui/index.html +15 -0
  230. package/dist/repertoire/ado-client.js +15 -56
  231. package/dist/repertoire/ado-semantic.js +11 -10
  232. package/dist/repertoire/api-client.js +97 -0
  233. package/dist/repertoire/bitwarden-store.js +816 -0
  234. package/dist/repertoire/bundle-templates.js +72 -0
  235. package/dist/repertoire/bw-installer.js +180 -0
  236. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  237. package/dist/repertoire/coding/context-pack.js +330 -0
  238. package/dist/repertoire/coding/feedback.js +197 -30
  239. package/dist/repertoire/coding/manager.js +158 -9
  240. package/dist/repertoire/coding/spawner.js +55 -9
  241. package/dist/repertoire/coding/tools.js +170 -7
  242. package/dist/repertoire/commerce-errors.js +109 -0
  243. package/dist/repertoire/commerce-self-test.js +156 -0
  244. package/dist/repertoire/credential-access.js +111 -0
  245. package/dist/repertoire/duffel-client.js +185 -0
  246. package/dist/repertoire/github-client.js +14 -55
  247. package/dist/repertoire/graph-client.js +11 -52
  248. package/dist/repertoire/guardrails.js +396 -0
  249. package/dist/repertoire/mcp-client.js +255 -0
  250. package/dist/repertoire/mcp-manager.js +305 -0
  251. package/dist/repertoire/mcp-tools.js +63 -0
  252. package/dist/repertoire/shell-sessions.js +133 -0
  253. package/dist/repertoire/skills.js +15 -24
  254. package/dist/repertoire/stripe-client.js +131 -0
  255. package/dist/repertoire/tasks/board.js +31 -5
  256. package/dist/repertoire/tasks/fix.js +182 -0
  257. package/dist/repertoire/tasks/index.js +16 -4
  258. package/dist/repertoire/tasks/lifecycle.js +2 -2
  259. package/dist/repertoire/tasks/parser.js +3 -2
  260. package/dist/repertoire/tasks/scanner.js +194 -37
  261. package/dist/repertoire/tasks/transitions.js +16 -78
  262. package/dist/repertoire/tool-results.js +29 -0
  263. package/dist/repertoire/tools-attachments.js +317 -0
  264. package/dist/repertoire/tools-base.js +47 -1075
  265. package/dist/repertoire/tools-bluebubbles.js +1 -0
  266. package/dist/repertoire/tools-bridge.js +142 -0
  267. package/dist/repertoire/tools-bundle.js +984 -0
  268. package/dist/repertoire/tools-config.js +185 -0
  269. package/dist/repertoire/tools-continuity.js +248 -0
  270. package/dist/repertoire/tools-credential.js +381 -0
  271. package/dist/repertoire/tools-files.js +342 -0
  272. package/dist/repertoire/tools-flight.js +224 -0
  273. package/dist/repertoire/tools-flow.js +119 -0
  274. package/dist/repertoire/tools-github.js +1 -7
  275. package/dist/repertoire/tools-mail.js +1477 -0
  276. package/dist/repertoire/tools-notes.js +421 -0
  277. package/dist/repertoire/tools-session.js +750 -0
  278. package/dist/repertoire/tools-shell.js +120 -0
  279. package/dist/repertoire/tools-stripe.js +180 -0
  280. package/dist/repertoire/tools-surface.js +243 -0
  281. package/dist/repertoire/tools-teams.js +9 -39
  282. package/dist/repertoire/tools-travel.js +125 -0
  283. package/dist/repertoire/tools-trip.js +422 -0
  284. package/dist/repertoire/tools-user-profile.js +144 -0
  285. package/dist/repertoire/tools-vault.js +40 -0
  286. package/dist/repertoire/tools.js +108 -100
  287. package/dist/repertoire/travel-api-client.js +360 -0
  288. package/dist/repertoire/user-profile.js +131 -0
  289. package/dist/repertoire/vault-setup.js +246 -0
  290. package/dist/repertoire/vault-unlock.js +561 -0
  291. package/dist/scripts/claude-code-hook.js +41 -0
  292. package/dist/scripts/claude-code-stop-hook.js +47 -0
  293. package/dist/senses/attention-queue.js +116 -0
  294. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  295. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  296. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
  297. package/dist/senses/bluebubbles/entry.js +77 -0
  298. package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
  299. package/dist/senses/bluebubbles/index.js +1947 -0
  300. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  301. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
  302. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
  303. package/dist/senses/bluebubbles/processed-log.js +111 -0
  304. package/dist/senses/bluebubbles/replay.js +129 -0
  305. package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +2 -2
  306. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  307. package/dist/senses/cli/bracketed-paste.js +82 -0
  308. package/dist/senses/cli/image-paste.js +287 -0
  309. package/dist/senses/cli/image-ref-navigation.js +75 -0
  310. package/dist/senses/cli/ink-app.js +156 -0
  311. package/dist/senses/cli/inline-diff.js +64 -0
  312. package/dist/senses/cli/input-keys.js +174 -0
  313. package/dist/senses/cli/kill-ring.js +86 -0
  314. package/dist/senses/cli/message-list.js +51 -0
  315. package/dist/senses/cli/ouro-tui.js +607 -0
  316. package/dist/senses/cli/spinner-imperative.js +135 -0
  317. package/dist/senses/cli/spinner.js +101 -0
  318. package/dist/senses/cli/status-line.js +60 -0
  319. package/dist/senses/cli/streaming-markdown.js +526 -0
  320. package/dist/senses/cli/tool-display.js +85 -0
  321. package/dist/senses/cli/tool-render.js +85 -0
  322. package/dist/senses/cli/tui-store.js +240 -0
  323. package/dist/senses/cli/virtual-list.js +35 -0
  324. package/dist/senses/cli-entry.js +60 -8
  325. package/dist/senses/cli-layout.js +187 -0
  326. package/dist/senses/cli.js +520 -209
  327. package/dist/senses/commands.js +66 -3
  328. package/dist/senses/habit-turn-message.js +108 -0
  329. package/dist/senses/inner-dialog-worker.js +175 -21
  330. package/dist/senses/inner-dialog.js +330 -27
  331. package/dist/senses/mail-entry.js +66 -0
  332. package/dist/senses/mail.js +379 -0
  333. package/dist/senses/pipeline.js +569 -182
  334. package/dist/senses/proactive-content-guard.js +51 -0
  335. package/dist/senses/shared-turn.js +248 -0
  336. package/dist/senses/surface-tool.js +68 -0
  337. package/dist/senses/teams-entry.js +60 -8
  338. package/dist/senses/teams.js +387 -98
  339. package/dist/senses/trust-gate.js +100 -5
  340. package/dist/trips/core.js +138 -0
  341. package/dist/trips/store.js +146 -0
  342. package/package.json +37 -7
  343. package/skills/agent-commerce.md +106 -0
  344. package/skills/browser-navigation.md +117 -0
  345. package/skills/commerce-setup-guide.md +116 -0
  346. package/skills/commerce-setup.md +84 -0
  347. package/skills/configure-dev-tools.md +101 -0
  348. package/skills/travel-planning.md +138 -0
  349. package/dist/heart/daemon/ouro-path-installer.js +0 -178
  350. package/dist/heart/daemon/subagent-installer.js +0 -166
  351. package/dist/heart/session-recall.js +0 -116
  352. package/dist/mind/associative-recall.js +0 -209
  353. package/dist/senses/bluebubbles-entry.js +0 -13
  354. package/dist/senses/bluebubbles.js +0 -1177
  355. package/dist/senses/debug-activity.js +0 -148
  356. package/subagents/README.md +0 -86
  357. package/subagents/work-doer.md +0 -237
  358. package/subagents/work-merger.md +0 -618
  359. package/subagents/work-planner.md +0 -390
  360. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  361. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  362. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  363. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  364. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  365. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  366. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  367. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  368. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  369. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  370. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  371. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  372. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  373. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  374. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  375. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ // Pluggable session ID resolver for MCP conversations.
3
+ // Tries tool-specific methods first, falls back to UUID.
4
+ //
5
+ // Claude Code: walks parent PID chain -> reads ~/.claude/sessions/{pid}.json
6
+ // Codex: reads thread_id from env (future)
7
+ // Fallback: generates UUID
8
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
9
+ if (k2 === undefined) k2 = k;
10
+ var desc = Object.getOwnPropertyDescriptor(m, k);
11
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
12
+ desc = { enumerable: true, get: function() { return m[k]; } };
13
+ }
14
+ Object.defineProperty(o, k2, desc);
15
+ }) : (function(o, m, k, k2) {
16
+ if (k2 === undefined) k2 = k;
17
+ o[k2] = m[k];
18
+ }));
19
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
20
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
21
+ }) : function(o, v) {
22
+ o["default"] = v;
23
+ });
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.resolveSessionId = resolveSessionId;
43
+ const fs = __importStar(require("fs"));
44
+ const path = __importStar(require("path"));
45
+ const os = __importStar(require("os"));
46
+ const crypto_1 = require("crypto");
47
+ const runtime_1 = require("../../nerves/runtime");
48
+ const DEFAULT_CLAUDE_SESSIONS_DIR = path.join(os.homedir(), ".claude", "sessions");
49
+ const MAX_PID_WALK_DEPTH = 10;
50
+ /**
51
+ * Try to read a Claude Code session ID from a PID-keyed session file.
52
+ * Returns the sessionId if found, null otherwise.
53
+ */
54
+ function tryReadClaudeSession(sessionsDir, pid) {
55
+ const sessionFile = path.join(sessionsDir, `${pid}.json`);
56
+ if (!fs.existsSync(sessionFile))
57
+ return null;
58
+ try {
59
+ const raw = fs.readFileSync(sessionFile, "utf-8");
60
+ const data = JSON.parse(raw);
61
+ if (typeof data.sessionId === "string" && data.sessionId.length > 0) {
62
+ return data.sessionId;
63
+ }
64
+ return null;
65
+ }
66
+ catch {
67
+ return null;
68
+ }
69
+ }
70
+ /**
71
+ * Walk the parent PID chain looking for a Claude Code session file.
72
+ * Starts at the current process PID, walks up to parent, grandparent, etc.
73
+ * Returns the session ID from the first matching file, or null.
74
+ */
75
+ function walkPidChain(sessionsDir) {
76
+ let currentPid = process.pid;
77
+ for (let depth = 0; depth < MAX_PID_WALK_DEPTH; depth++) {
78
+ const sessionId = tryReadClaudeSession(sessionsDir, currentPid);
79
+ if (sessionId) {
80
+ (0, runtime_1.emitNervesEvent)({
81
+ component: "daemon",
82
+ event: "daemon.session_id_pid_walk_hit",
83
+ message: "found Claude session via PID walk",
84
+ meta: { pid: currentPid, depth, sessionId },
85
+ });
86
+ return sessionId;
87
+ }
88
+ // Walk to parent PID
89
+ // On macOS/Linux, process.ppid gives the parent. For deeper ancestry,
90
+ // we'd need /proc/{pid}/stat or ps -o ppid=. For now, we check current + parent.
91
+ if (depth === 0) {
92
+ currentPid = process.ppid;
93
+ }
94
+ else {
95
+ // Cannot walk further without OS-specific process tree APIs
96
+ break;
97
+ }
98
+ }
99
+ return null;
100
+ }
101
+ /**
102
+ * Resolve a session ID for the current MCP connection.
103
+ * Returns a stable identifier that ties MCP tool calls to a conversation session.
104
+ *
105
+ * Resolution order:
106
+ * 1. Claude Code PID walk: check ~/.claude/sessions/{pid}.json for current + parent PID
107
+ * 2. UUID fallback: generate a random UUID
108
+ */
109
+ function resolveSessionId(options) {
110
+ const sessionsDir = options?.claudeSessionsDir ?? DEFAULT_CLAUDE_SESSIONS_DIR;
111
+ // Try Claude Code PID walk
112
+ const claudeSessionId = walkPidChain(sessionsDir);
113
+ if (claudeSessionId) {
114
+ (0, runtime_1.emitNervesEvent)({
115
+ component: "daemon",
116
+ event: "daemon.session_id_resolved",
117
+ message: "session ID resolved via Claude Code PID walk",
118
+ meta: { sessionId: claudeSessionId, method: "claude-pid-walk" },
119
+ });
120
+ return claudeSessionId;
121
+ }
122
+ // Fallback: UUID
123
+ const sessionId = (0, crypto_1.randomUUID)();
124
+ (0, runtime_1.emitNervesEvent)({
125
+ component: "daemon",
126
+ event: "daemon.session_id_resolved",
127
+ message: "session ID resolved via UUID fallback",
128
+ meta: { sessionId, method: "uuid-fallback" },
129
+ });
130
+ return sessionId;
131
+ }
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.ensureSkillManagement = ensureSkillManagement;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const runtime_1 = require("../../nerves/runtime");
40
+ const identity_1 = require("../identity");
41
+ const SKILL_MANAGEMENT_URL = "https://raw.githubusercontent.com/ouroborosbot/ouroboros-skills/main/skills/skill-management/SKILL.md";
42
+ async function ensureSkillManagement() {
43
+ const bundlesRoot = (0, identity_1.getAgentBundlesRoot)();
44
+ if (!fs.existsSync(bundlesRoot))
45
+ return;
46
+ // Find all agent bundles
47
+ const entries = fs.readdirSync(bundlesRoot).filter(e => e.endsWith(".ouro"));
48
+ if (entries.length === 0)
49
+ return;
50
+ // Check if ANY bundle is missing the skill
51
+ const missing = entries.filter(e => {
52
+ const targetPath = path.join(bundlesRoot, e, "skills", "skill-management.md");
53
+ return !fs.existsSync(targetPath);
54
+ });
55
+ if (missing.length === 0)
56
+ return;
57
+ // eslint-disable-next-line no-console -- terminal UX: visible install status
58
+ console.log("installing skill-management from ouroboros-skills...");
59
+ try {
60
+ const response = await fetch(SKILL_MANAGEMENT_URL);
61
+ if (!response.ok) {
62
+ // eslint-disable-next-line no-console -- terminal UX: visible install status
63
+ console.error(`✗ failed to fetch skill-management (HTTP ${response.status})`);
64
+ (0, runtime_1.emitNervesEvent)({
65
+ level: "warn",
66
+ component: "daemon",
67
+ event: "daemon.skill_management_install_error",
68
+ message: "failed to fetch skill-management from GitHub",
69
+ meta: { status: response.status, url: SKILL_MANAGEMENT_URL },
70
+ });
71
+ return;
72
+ }
73
+ const content = await response.text();
74
+ for (const bundle of missing) {
75
+ const skillsDir = path.join(bundlesRoot, bundle, "skills");
76
+ const targetPath = path.join(skillsDir, "skill-management.md");
77
+ fs.mkdirSync(skillsDir, { recursive: true });
78
+ fs.writeFileSync(targetPath, content, "utf-8");
79
+ }
80
+ // eslint-disable-next-line no-console -- terminal UX: visible install status
81
+ console.log(`✓ installed skill-management (${missing.length} agent${missing.length > 1 ? "s" : ""})`);
82
+ }
83
+ catch (error) {
84
+ // eslint-disable-next-line no-console -- terminal UX: visible install status
85
+ console.error(`✗ failed to install skill-management: ${error instanceof Error ? error.message : String(error)}`);
86
+ (0, runtime_1.emitNervesEvent)({
87
+ level: "warn",
88
+ component: "daemon",
89
+ event: "daemon.skill_management_install_error",
90
+ message: "failed to install skill-management skill",
91
+ meta: { error: error instanceof Error ? error.message : String(error) },
92
+ });
93
+ }
94
+ }
@@ -34,6 +34,7 @@ var __importStar = (this && this.__importStar) || (function () {
34
34
  })();
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
36
  exports.DEFAULT_DAEMON_SOCKET_PATH = void 0;
37
+ exports.__bypassVitestGuardForTests = __bypassVitestGuardForTests;
37
38
  exports.sendDaemonCommand = sendDaemonCommand;
38
39
  exports.checkDaemonSocketAlive = checkDaemonSocketAlive;
39
40
  exports.requestInnerWake = requestInnerWake;
@@ -41,7 +42,81 @@ const fs = __importStar(require("fs"));
41
42
  const net = __importStar(require("net"));
42
43
  const runtime_1 = require("../../nerves/runtime");
43
44
  exports.DEFAULT_DAEMON_SOCKET_PATH = "/tmp/ouroboros-daemon.sock";
45
+ /**
46
+ * Defense-in-depth: detect if we're running under vitest. Tests that forget
47
+ * to `vi.mock("../../heart/daemon/socket-client")` would otherwise leak real
48
+ * `inner.wake` commands (with whatever literal agent name the test uses,
49
+ * commonly "testagent") into whichever real daemon happens to be running on
50
+ * the developer's machine. That has caused real outages when test loops
51
+ * flooded the production-on-localhost daemon.
52
+ *
53
+ * We detect vitest via `process.argv` (not env vars — the project bans those)
54
+ * and convert all socket operations into safe no-ops. Individual tests are
55
+ * still expected to vi.mock this module so they can assert on call counts,
56
+ * but this guard guarantees that "I forgot to mock" can never again take
57
+ * down the daemon.
58
+ *
59
+ * The socket-client's OWN tests (which exercise the real functions against a
60
+ * test socket) call `__bypassVitestGuardForTests(true)` to opt out of the
61
+ * guard. We persist that flag on globalThis so it survives `vi.resetModules`
62
+ * (which clears the module cache between tests).
63
+ *
64
+ * HARDENING (cross-file leak protection): the bypass flag lives on globalThis
65
+ * and is process-wide. With vitest's default `fileParallelism: true`,
66
+ * concurrently-running test files in the same worker can have the bypass on
67
+ * even though they didn't ask for it — and any test that uses
68
+ * `name: "testagent"` and exercises a code path through this module will
69
+ * leak `inner.wake testagent` to the production daemon socket. We saw this
70
+ * cause a real outage on 2026-04-08 (daemon SIGTERMed mid-validation).
71
+ *
72
+ * Defense: even when the bypass flag is set, we ALWAYS hard-block calls that
73
+ * target the production daemon socket path. Test files that legitimately
74
+ * exercise the real socket-client code paths use a synthetic socket path like
75
+ * `/tmp/daemon.sock` or `/tmp/some-real-daemon.sock` — those keep working.
76
+ * Calls to `/tmp/ouroboros-daemon.sock` (DEFAULT_DAEMON_SOCKET_PATH) under
77
+ * vitest are unconditionally blocked, regardless of bypass state. This makes
78
+ * the cross-file leak vector impossible without restricting legitimate
79
+ * socket-client unit tests.
80
+ */
81
+ const BYPASS_KEY = "__ouro_socket_client_bypass_vitest_guard__";
82
+ /** ONLY for socket-client.test.ts. Do not call from any other test or production code. */
83
+ function __bypassVitestGuardForTests(bypass) {
84
+ ;
85
+ globalThis[BYPASS_KEY] = bypass;
86
+ }
87
+ function isVitestProcess() {
88
+ /* v8 ignore next -- defensive: process and process.argv always exist in node @preserve */
89
+ if (typeof process === "undefined" || !Array.isArray(process.argv))
90
+ return false;
91
+ return process.argv.some((arg) => typeof arg === "string" && arg.includes("vitest"));
92
+ }
93
+ function isProductionDaemonSocket(socketPath) {
94
+ return socketPath === exports.DEFAULT_DAEMON_SOCKET_PATH;
95
+ }
96
+ /**
97
+ * Returns true when this socket call should be converted into a safe no-op
98
+ * because we're under vitest and the call would otherwise leak into a real
99
+ * daemon. The bypass flag short-circuits the guard for non-production socket
100
+ * paths only — production socket paths are ALWAYS blocked under vitest.
101
+ */
102
+ function shouldSuppressSocketCall(socketPath) {
103
+ if (!isVitestProcess())
104
+ return false;
105
+ if (isProductionDaemonSocket(socketPath))
106
+ return true;
107
+ return globalThis[BYPASS_KEY] !== true;
108
+ }
44
109
  function sendDaemonCommand(socketPath, command) {
110
+ if (shouldSuppressSocketCall(socketPath)) {
111
+ (0, runtime_1.emitNervesEvent)({
112
+ level: "warn",
113
+ component: "daemon",
114
+ event: "daemon.socket_command_test_blocked",
115
+ message: "blocked socket command from leaking into real daemon under vitest",
116
+ meta: { socketPath, kind: command.kind, isProductionSocket: isProductionDaemonSocket(socketPath) },
117
+ });
118
+ return Promise.resolve({ ok: true, message: "test mode: socket call suppressed" });
119
+ }
45
120
  (0, runtime_1.emitNervesEvent)({
46
121
  component: "daemon",
47
122
  event: "daemon.socket_command_start",
@@ -52,8 +127,23 @@ function sendDaemonCommand(socketPath, command) {
52
127
  const client = net.createConnection(socketPath);
53
128
  let raw = "";
54
129
  client.on("connect", () => {
55
- client.write(JSON.stringify(command));
56
- client.end();
130
+ // Write the command + newline delimiter. DO NOT call client.end()
131
+ // afterwards — the server closes the connection once it has written
132
+ // its response, which triggers our on("end") handler with the full
133
+ // response in `raw`.
134
+ //
135
+ // Calling client.end() here half-closes the TCP connection. The
136
+ // daemon server uses net.createServer() with the default
137
+ // allowHalfOpen: false, so when the server sees the client's FIN it
138
+ // auto-closes its own writable side — and any response the server
139
+ // tries to write after processing a long-running command (like
140
+ // agent.senseTurn, which runs a full LLM turn) gets dropped on the
141
+ // floor. Verified via repro: with client.end(), agent.senseTurn
142
+ // returns empty in ~149ms; without it, the same call returns the real
143
+ // response in ~5.8s. This is a regression of the fix in #303 that
144
+ // was silently reverted by 253e4b1f (commit titled "socket half-close
145
+ // fix" but actually *added* the half-close back).
146
+ client.write(JSON.stringify(command) + "\n");
57
147
  });
58
148
  client.on("data", (chunk) => {
59
149
  raw += chunk.toString("utf-8");
@@ -132,6 +222,9 @@ function sendDaemonCommand(socketPath, command) {
132
222
  });
133
223
  }
134
224
  function checkDaemonSocketAlive(socketPath) {
225
+ if (shouldSuppressSocketCall(socketPath)) {
226
+ return Promise.resolve(false);
227
+ }
135
228
  (0, runtime_1.emitNervesEvent)({
136
229
  component: "daemon",
137
230
  event: "daemon.socket_alive_check_start",
@@ -161,8 +254,10 @@ function checkDaemonSocketAlive(socketPath) {
161
254
  });
162
255
  }
163
256
  client.on("connect", () => {
164
- client.write(JSON.stringify({ kind: "daemon.status" }));
165
- client.end();
257
+ // Same half-close rationale as sendDaemonCommand: do NOT call
258
+ // client.end() here. The server closes after responding and that
259
+ // triggers the on("end") handler below.
260
+ client.write(JSON.stringify({ kind: "daemon.status" }) + "\n");
166
261
  });
167
262
  client.on("data", (chunk) => {
168
263
  raw += chunk.toString("utf-8");
@@ -184,6 +279,16 @@ function checkDaemonSocketAlive(socketPath) {
184
279
  });
185
280
  }
186
281
  async function requestInnerWake(agent, socketPath = exports.DEFAULT_DAEMON_SOCKET_PATH) {
282
+ if (shouldSuppressSocketCall(socketPath)) {
283
+ (0, runtime_1.emitNervesEvent)({
284
+ level: "warn",
285
+ component: "daemon",
286
+ event: "daemon.inner_wake_test_blocked",
287
+ message: "blocked inner wake from leaking into real daemon under vitest",
288
+ meta: { agent, socketPath, isProductionSocket: isProductionDaemonSocket(socketPath) },
289
+ });
290
+ return null;
291
+ }
187
292
  const socketAvailable = fs.existsSync(socketPath);
188
293
  (0, runtime_1.emitNervesEvent)({
189
294
  component: "daemon",
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.pruneStaleEphemeralBundles = pruneStaleEphemeralBundles;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const identity_1 = require("../identity");
40
+ const runtime_1 = require("../../nerves/runtime");
41
+ /**
42
+ * Scan the bundles root for `.ouro` directories that have no `agent.json`
43
+ * file (definitively dead ephemeral bundles) and delete them.
44
+ *
45
+ * Returns a list of pruned bundle directory names (e.g. `["stale.ouro"]`)
46
+ * for display purposes. Bundles that have `agent.json` -- even if disabled
47
+ * -- are never deleted. Errors on individual bundles are swallowed so that
48
+ * one permission-denied doesn't block pruning the rest.
49
+ */
50
+ function pruneStaleEphemeralBundles(deps = {}) {
51
+ const bundlesRoot = deps.bundlesRoot ?? (0, identity_1.getAgentBundlesRoot)();
52
+ const readdirSync = deps.readdirSync ?? fs.readdirSync;
53
+ const existsSync = deps.existsSync ?? fs.existsSync;
54
+ const rmSync = deps.rmSync ?? fs.rmSync;
55
+ let entries;
56
+ try {
57
+ entries = readdirSync(bundlesRoot, { withFileTypes: true });
58
+ }
59
+ catch {
60
+ return [];
61
+ }
62
+ const pruned = [];
63
+ for (const entry of entries) {
64
+ if (!entry.isDirectory() || !entry.name.endsWith(".ouro"))
65
+ continue;
66
+ const bundlePath = path.join(bundlesRoot, entry.name);
67
+ const agentJsonPath = path.join(bundlePath, "agent.json");
68
+ if (existsSync(agentJsonPath))
69
+ continue;
70
+ try {
71
+ rmSync(bundlePath, { recursive: true, force: true });
72
+ pruned.push(entry.name);
73
+ (0, runtime_1.emitNervesEvent)({
74
+ level: "info",
75
+ component: "daemon",
76
+ event: "daemon.stale_bundle_pruned",
77
+ message: `pruned stale ephemeral bundle: ${entry.name}`,
78
+ meta: { bundle: entry.name, bundlePath },
79
+ });
80
+ }
81
+ catch (error) {
82
+ (0, runtime_1.emitNervesEvent)({
83
+ level: "warn",
84
+ component: "daemon",
85
+ event: "daemon.stale_bundle_prune_error",
86
+ message: `failed to prune stale bundle: ${entry.name}`,
87
+ meta: {
88
+ bundle: entry.name,
89
+ bundlePath,
90
+ error: error instanceof Error ? error.message : String(error),
91
+ },
92
+ });
93
+ }
94
+ }
95
+ return pruned;
96
+ }