@ouro.bot/cli 0.1.0-alpha.55 → 0.1.0-alpha.551

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 (386) hide show
  1. package/README.md +133 -19
  2. package/RepairGuide.ouro/agent.json +5 -0
  3. package/RepairGuide.ouro/psyche/IDENTITY.md +19 -0
  4. package/RepairGuide.ouro/psyche/SOUL.md +55 -0
  5. package/RepairGuide.ouro/skills/diagnose-bootstrap-drift.md +54 -0
  6. package/RepairGuide.ouro/skills/diagnose-broken-remote.md +63 -0
  7. package/RepairGuide.ouro/skills/diagnose-stacked-typed-issues.md +35 -0
  8. package/RepairGuide.ouro/skills/diagnose-sync-blocked.md +54 -0
  9. package/RepairGuide.ouro/skills/diagnose-vault-expired.md +60 -0
  10. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +4 -2
  11. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
  12. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  13. package/changelog.json +3561 -0
  14. package/dist/arc/attention-types.js +8 -0
  15. package/dist/arc/cares.js +140 -0
  16. package/dist/arc/episodes.js +117 -0
  17. package/dist/arc/intentions.js +133 -0
  18. package/dist/arc/json-store.js +117 -0
  19. package/dist/arc/obligations.js +237 -0
  20. package/dist/arc/packets.js +193 -0
  21. package/dist/arc/presence.js +185 -0
  22. package/dist/arc/task-lifecycle.js +65 -0
  23. package/dist/heart/active-work.js +837 -26
  24. package/dist/heart/agent-entry.js +58 -3
  25. package/dist/heart/attachments/image-normalize.js +194 -0
  26. package/dist/heart/attachments/materialize.js +97 -0
  27. package/dist/heart/attachments/originals.js +88 -0
  28. package/dist/heart/attachments/render.js +29 -0
  29. package/dist/heart/attachments/sources/adapter.js +2 -0
  30. package/dist/heart/attachments/sources/bluebubbles.js +156 -0
  31. package/dist/heart/attachments/sources/cli-local-file.js +78 -0
  32. package/dist/heart/attachments/sources/index.js +16 -0
  33. package/dist/heart/attachments/store.js +103 -0
  34. package/dist/heart/attachments/types.js +93 -0
  35. package/dist/heart/auth/auth-flow.js +479 -0
  36. package/dist/heart/background-operations.js +281 -0
  37. package/dist/heart/bundle-state.js +168 -0
  38. package/dist/heart/commitments.js +111 -0
  39. package/dist/heart/config-registry.js +304 -0
  40. package/dist/heart/config.js +114 -118
  41. package/dist/heart/core.js +925 -246
  42. package/dist/heart/cross-chat-delivery.js +3 -18
  43. package/dist/heart/daemon/agent-config-check.js +512 -0
  44. package/dist/heart/daemon/agent-discovery.js +102 -3
  45. package/dist/heart/daemon/agent-service.js +522 -0
  46. package/dist/heart/daemon/agentic-repair.js +554 -0
  47. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  48. package/dist/heart/daemon/boot-sync-probe.js +197 -0
  49. package/dist/heart/daemon/cadence.js +70 -0
  50. package/dist/heart/daemon/cli-defaults.js +665 -0
  51. package/dist/heart/daemon/cli-exec.js +7565 -0
  52. package/dist/heart/daemon/cli-help.js +498 -0
  53. package/dist/heart/daemon/cli-parse.js +1590 -0
  54. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  55. package/dist/heart/daemon/cli-render.js +775 -0
  56. package/dist/heart/daemon/cli-types.js +8 -0
  57. package/dist/heart/daemon/connect-bay.js +323 -0
  58. package/dist/heart/daemon/daemon-cli.js +29 -1672
  59. package/dist/heart/daemon/daemon-entry.js +417 -2
  60. package/dist/heart/daemon/daemon-health.js +183 -0
  61. package/dist/heart/daemon/daemon-rollup.js +58 -0
  62. package/dist/heart/daemon/daemon-runtime-sync.js +87 -13
  63. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  64. package/dist/heart/daemon/daemon.js +796 -71
  65. package/dist/heart/daemon/dns-workflow.js +394 -0
  66. package/dist/heart/daemon/doctor-types.js +8 -0
  67. package/dist/heart/daemon/doctor.js +844 -0
  68. package/dist/heart/daemon/drift-detection.js +146 -0
  69. package/dist/heart/daemon/health-monitor.js +122 -1
  70. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  71. package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
  72. package/dist/heart/daemon/http-health-probe.js +80 -0
  73. package/dist/heart/daemon/human-command-screens.js +234 -0
  74. package/dist/heart/daemon/human-readiness.js +114 -0
  75. package/dist/heart/daemon/inner-status.js +102 -0
  76. package/dist/heart/daemon/interactive-repair.js +394 -0
  77. package/dist/heart/daemon/launchd.js +37 -8
  78. package/dist/heart/daemon/log-tailer.js +82 -12
  79. package/dist/heart/daemon/logs-prune.js +110 -0
  80. package/dist/heart/daemon/mcp-canary.js +297 -0
  81. package/dist/heart/daemon/message-router.js +2 -2
  82. package/dist/heart/daemon/os-cron-deps.js +135 -0
  83. package/dist/heart/daemon/os-cron.js +14 -12
  84. package/dist/heart/daemon/ouro-bot-entry.js +4 -2
  85. package/dist/heart/daemon/ouro-entry.js +3 -1
  86. package/dist/heart/daemon/process-manager.js +375 -33
  87. package/dist/heart/daemon/provider-discovery.js +137 -0
  88. package/dist/heart/daemon/provider-ping-progress.js +83 -0
  89. package/dist/heart/daemon/pulse.js +475 -0
  90. package/dist/heart/daemon/readiness-repair.js +365 -0
  91. package/dist/heart/daemon/run-hooks.js +2 -0
  92. package/dist/heart/daemon/runtime-logging.js +67 -16
  93. package/dist/heart/daemon/runtime-metadata.js +3 -31
  94. package/dist/heart/daemon/safe-mode.js +161 -0
  95. package/dist/heart/daemon/sense-manager.js +353 -38
  96. package/dist/heart/daemon/session-id-resolver.js +131 -0
  97. package/dist/heart/daemon/skill-management-installer.js +94 -0
  98. package/dist/heart/daemon/socket-client.js +158 -11
  99. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  100. package/dist/heart/daemon/startup-tui.js +330 -0
  101. package/dist/heart/daemon/task-scheduler.js +3 -25
  102. package/dist/heart/daemon/terminal-ui.js +499 -0
  103. package/dist/heart/daemon/thoughts.js +162 -17
  104. package/dist/heart/daemon/up-progress.js +366 -0
  105. package/dist/heart/daemon/vault-items.js +56 -0
  106. package/dist/heart/delegation.js +1 -1
  107. package/dist/heart/habits/habit-migration.js +189 -0
  108. package/dist/heart/habits/habit-parser.js +140 -0
  109. package/dist/heart/habits/habit-runtime-state.js +100 -0
  110. package/dist/heart/habits/habit-scheduler.js +372 -0
  111. package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
  112. package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
  113. package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
  114. package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
  115. package/dist/heart/identity.js +200 -51
  116. package/dist/heart/kept-notes.js +357 -0
  117. package/dist/heart/kicks.js +1 -1
  118. package/dist/heart/machine-identity.js +161 -0
  119. package/dist/heart/mail-import-discovery.js +353 -0
  120. package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
  121. package/dist/heart/mailbox/mailbox-http-response.js +7 -0
  122. package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
  123. package/dist/heart/mailbox/mailbox-http-static.js +103 -0
  124. package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
  125. package/dist/heart/mailbox/mailbox-http.js +99 -0
  126. package/dist/heart/mailbox/mailbox-read.js +31 -0
  127. package/dist/heart/mailbox/mailbox-types.js +27 -0
  128. package/dist/heart/mailbox/mailbox-view.js +195 -0
  129. package/dist/heart/mailbox/readers/agent-machine.js +382 -0
  130. package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
  131. package/dist/heart/mailbox/readers/mail.js +362 -0
  132. package/dist/heart/mailbox/readers/runtime-readers.js +651 -0
  133. package/dist/heart/mailbox/readers/sessions.js +232 -0
  134. package/dist/heart/mailbox/readers/shared.js +111 -0
  135. package/dist/heart/mcp/mcp-server.js +683 -0
  136. package/dist/heart/migrate-config.js +100 -0
  137. package/dist/heart/model-capabilities.js +19 -0
  138. package/dist/heart/platform.js +81 -0
  139. package/dist/heart/provider-attempt.js +134 -0
  140. package/dist/heart/provider-binding-resolver.js +255 -0
  141. package/dist/heart/provider-credentials.js +425 -0
  142. package/dist/heart/provider-failover.js +301 -0
  143. package/dist/heart/provider-models.js +81 -0
  144. package/dist/heart/provider-ping.js +262 -0
  145. package/dist/heart/provider-state.js +216 -0
  146. package/dist/heart/provider-visibility.js +188 -0
  147. package/dist/heart/providers/anthropic-token.js +131 -0
  148. package/dist/heart/providers/anthropic.js +139 -52
  149. package/dist/heart/providers/azure.js +97 -13
  150. package/dist/heart/providers/error-classification.js +127 -0
  151. package/dist/heart/providers/github-copilot.js +145 -0
  152. package/dist/heart/providers/minimax-vlm.js +189 -0
  153. package/dist/heart/providers/minimax.js +26 -8
  154. package/dist/heart/providers/openai-codex.js +55 -40
  155. package/dist/heart/runtime-capability-check.js +170 -0
  156. package/dist/heart/runtime-credentials.js +367 -0
  157. package/dist/heart/runtime-cwd.js +87 -0
  158. package/dist/heart/sense-truth.js +11 -4
  159. package/dist/heart/session-activity.js +43 -22
  160. package/dist/heart/session-events.js +1149 -0
  161. package/dist/heart/session-playback-cli-main.js +5 -0
  162. package/dist/heart/session-playback-cli.js +36 -0
  163. package/dist/heart/session-playback.js +231 -0
  164. package/dist/heart/session-stats-cli-main.js +5 -0
  165. package/dist/heart/session-stats.js +182 -0
  166. package/dist/heart/session-transcript.js +243 -0
  167. package/dist/heart/start-of-turn-packet.js +345 -0
  168. package/dist/heart/streaming.js +44 -27
  169. package/dist/heart/sync-classification.js +176 -0
  170. package/dist/heart/sync.js +449 -0
  171. package/dist/heart/target-resolution.js +9 -5
  172. package/dist/heart/tempo.js +93 -0
  173. package/dist/heart/temporal-view.js +41 -0
  174. package/dist/heart/timeouts.js +101 -0
  175. package/dist/heart/tool-activity-callbacks.js +59 -0
  176. package/dist/heart/tool-description.js +139 -0
  177. package/dist/heart/tool-friction.js +55 -0
  178. package/dist/heart/tool-loop.js +200 -0
  179. package/dist/heart/turn-context.js +381 -0
  180. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +6 -5
  181. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  182. package/dist/heart/versioning/ouro-path-installer.js +426 -0
  183. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  184. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  185. package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
  186. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  187. package/dist/mailbox-ui/assets/index-BPr5vNuM.css +1 -0
  188. package/dist/mailbox-ui/assets/index-Cm51CY9W.js +61 -0
  189. package/dist/mailbox-ui/index.html +15 -0
  190. package/dist/mailroom/attention.js +167 -0
  191. package/dist/mailroom/autonomy.js +209 -0
  192. package/dist/mailroom/blob-store.js +674 -0
  193. package/dist/mailroom/body-cache.js +61 -0
  194. package/dist/mailroom/core.js +720 -0
  195. package/dist/mailroom/entry.js +160 -0
  196. package/dist/mailroom/file-store.js +430 -0
  197. package/dist/mailroom/mbox-import.js +383 -0
  198. package/dist/mailroom/outbound.js +380 -0
  199. package/dist/mailroom/policy.js +263 -0
  200. package/dist/mailroom/reader.js +233 -0
  201. package/dist/mailroom/search-cache.js +256 -0
  202. package/dist/mailroom/search-relevance.js +319 -0
  203. package/dist/mailroom/smtp-ingress.js +176 -0
  204. package/dist/mailroom/source-state.js +176 -0
  205. package/dist/mailroom/thread.js +109 -0
  206. package/dist/mailroom/travel-extract.js +89 -0
  207. package/dist/mind/bundle-manifest.js +7 -1
  208. package/dist/mind/context.js +165 -101
  209. package/dist/mind/diary-integrity.js +60 -0
  210. package/dist/mind/{memory.js → diary.js} +62 -75
  211. package/dist/mind/embedding-provider.js +60 -0
  212. package/dist/mind/file-state.js +179 -0
  213. package/dist/mind/friends/channel.js +30 -0
  214. package/dist/mind/friends/resolver.js +54 -2
  215. package/dist/mind/friends/store-file.js +39 -3
  216. package/dist/mind/friends/types.js +2 -2
  217. package/dist/mind/journal-index.js +161 -0
  218. package/dist/mind/note-search.js +268 -0
  219. package/dist/mind/obligation-steering.js +221 -0
  220. package/dist/mind/pending.js +4 -0
  221. package/dist/mind/prompt-refresh.js +3 -2
  222. package/dist/mind/prompt.js +995 -123
  223. package/dist/mind/provenance-trust.js +26 -0
  224. package/dist/mind/scrutiny.js +173 -0
  225. package/dist/nerves/cli-logging.js +7 -1
  226. package/dist/nerves/coverage/audit-rules.js +15 -6
  227. package/dist/nerves/coverage/audit.js +28 -2
  228. package/dist/nerves/coverage/cli.js +1 -1
  229. package/dist/nerves/coverage/contract.js +5 -5
  230. package/dist/nerves/coverage/file-completeness.js +139 -5
  231. package/dist/nerves/coverage/run-artifacts.js +1 -1
  232. package/dist/nerves/event-buffer.js +111 -0
  233. package/dist/nerves/index.js +224 -4
  234. package/dist/nerves/observation.js +20 -0
  235. package/dist/nerves/redact.js +79 -0
  236. package/dist/nerves/review/cli-main.js +5 -0
  237. package/dist/nerves/review/cli.js +156 -0
  238. package/dist/nerves/review/core.js +152 -0
  239. package/dist/nerves/runtime.js +5 -1
  240. package/dist/repertoire/ado-client.js +15 -56
  241. package/dist/repertoire/ado-semantic.js +11 -10
  242. package/dist/repertoire/api-client.js +97 -0
  243. package/dist/repertoire/bitwarden-store.js +816 -0
  244. package/dist/repertoire/bundle-templates.js +72 -0
  245. package/dist/repertoire/bw-installer.js +180 -0
  246. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  247. package/dist/repertoire/coding/context-pack.js +330 -0
  248. package/dist/repertoire/coding/feedback.js +197 -30
  249. package/dist/repertoire/coding/manager.js +158 -9
  250. package/dist/repertoire/coding/spawner.js +55 -9
  251. package/dist/repertoire/coding/tools.js +170 -7
  252. package/dist/repertoire/commerce-errors.js +109 -0
  253. package/dist/repertoire/commerce-self-test.js +156 -0
  254. package/dist/repertoire/credential-access.js +111 -0
  255. package/dist/repertoire/duffel-client.js +185 -0
  256. package/dist/repertoire/github-client.js +14 -55
  257. package/dist/repertoire/graph-client.js +11 -52
  258. package/dist/repertoire/guardrails.js +396 -0
  259. package/dist/repertoire/mcp-client.js +295 -0
  260. package/dist/repertoire/mcp-manager.js +362 -0
  261. package/dist/repertoire/mcp-tools.js +63 -0
  262. package/dist/repertoire/shell-sessions.js +133 -0
  263. package/dist/repertoire/skills.js +15 -24
  264. package/dist/repertoire/stripe-client.js +131 -0
  265. package/dist/repertoire/tasks/board.js +31 -5
  266. package/dist/repertoire/tasks/fix.js +182 -0
  267. package/dist/repertoire/tasks/index.js +16 -4
  268. package/dist/repertoire/tasks/lifecycle.js +2 -2
  269. package/dist/repertoire/tasks/parser.js +3 -2
  270. package/dist/repertoire/tasks/scanner.js +194 -37
  271. package/dist/repertoire/tasks/transitions.js +16 -78
  272. package/dist/repertoire/tool-results.js +29 -0
  273. package/dist/repertoire/tools-attachments.js +317 -0
  274. package/dist/repertoire/tools-base.js +47 -1075
  275. package/dist/repertoire/tools-bluebubbles.js +1 -0
  276. package/dist/repertoire/tools-bridge.js +142 -0
  277. package/dist/repertoire/tools-bundle.js +984 -0
  278. package/dist/repertoire/tools-config.js +185 -0
  279. package/dist/repertoire/tools-continuity.js +248 -0
  280. package/dist/repertoire/tools-credential.js +381 -0
  281. package/dist/repertoire/tools-files.js +342 -0
  282. package/dist/repertoire/tools-flight.js +224 -0
  283. package/dist/repertoire/tools-flow.js +119 -0
  284. package/dist/repertoire/tools-github.js +1 -7
  285. package/dist/repertoire/tools-mail.js +1857 -0
  286. package/dist/repertoire/tools-notes.js +421 -0
  287. package/dist/repertoire/tools-session.js +750 -0
  288. package/dist/repertoire/tools-shell.js +120 -0
  289. package/dist/repertoire/tools-stripe.js +180 -0
  290. package/dist/repertoire/tools-surface.js +243 -0
  291. package/dist/repertoire/tools-teams.js +9 -39
  292. package/dist/repertoire/tools-travel.js +125 -0
  293. package/dist/repertoire/tools-trip.js +604 -0
  294. package/dist/repertoire/tools-user-profile.js +144 -0
  295. package/dist/repertoire/tools-vault.js +40 -0
  296. package/dist/repertoire/tools.js +108 -100
  297. package/dist/repertoire/travel-api-client.js +360 -0
  298. package/dist/repertoire/user-profile.js +131 -0
  299. package/dist/repertoire/vault-setup.js +246 -0
  300. package/dist/repertoire/vault-unlock.js +561 -0
  301. package/dist/scripts/claude-code-hook.js +41 -0
  302. package/dist/scripts/claude-code-stop-hook.js +47 -0
  303. package/dist/senses/attention-queue.js +116 -0
  304. package/dist/senses/bluebubbles/active-turns.js +216 -0
  305. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  306. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  307. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
  308. package/dist/senses/bluebubbles/entry.js +77 -0
  309. package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
  310. package/dist/senses/bluebubbles/index.js +2305 -0
  311. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  312. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
  313. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
  314. package/dist/senses/bluebubbles/processed-log.js +133 -0
  315. package/dist/senses/bluebubbles/replay.js +137 -0
  316. package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
  317. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  318. package/dist/senses/cli/bracketed-paste.js +82 -0
  319. package/dist/senses/cli/image-paste.js +287 -0
  320. package/dist/senses/cli/image-ref-navigation.js +75 -0
  321. package/dist/senses/cli/ink-app.js +156 -0
  322. package/dist/senses/cli/inline-diff.js +64 -0
  323. package/dist/senses/cli/input-keys.js +174 -0
  324. package/dist/senses/cli/kill-ring.js +86 -0
  325. package/dist/senses/cli/message-list.js +51 -0
  326. package/dist/senses/cli/ouro-tui.js +607 -0
  327. package/dist/senses/cli/spinner-imperative.js +135 -0
  328. package/dist/senses/cli/spinner.js +101 -0
  329. package/dist/senses/cli/status-line.js +60 -0
  330. package/dist/senses/cli/streaming-markdown.js +526 -0
  331. package/dist/senses/cli/tool-display.js +85 -0
  332. package/dist/senses/cli/tool-render.js +85 -0
  333. package/dist/senses/cli/tui-store.js +240 -0
  334. package/dist/senses/cli/virtual-list.js +35 -0
  335. package/dist/senses/cli-entry.js +60 -8
  336. package/dist/senses/cli-layout.js +187 -0
  337. package/dist/senses/cli.js +520 -209
  338. package/dist/senses/commands.js +66 -3
  339. package/dist/senses/habit-turn-message.js +108 -0
  340. package/dist/senses/inner-dialog-worker.js +175 -21
  341. package/dist/senses/inner-dialog.js +330 -27
  342. package/dist/senses/mail-entry.js +66 -0
  343. package/dist/senses/mail.js +379 -0
  344. package/dist/senses/pipeline.js +569 -182
  345. package/dist/senses/proactive-content-guard.js +51 -0
  346. package/dist/senses/shared-turn.js +248 -0
  347. package/dist/senses/surface-tool.js +68 -0
  348. package/dist/senses/teams-entry.js +60 -8
  349. package/dist/senses/teams.js +387 -98
  350. package/dist/senses/trust-gate.js +100 -5
  351. package/dist/trips/core.js +138 -0
  352. package/dist/trips/store.js +146 -0
  353. package/package.json +38 -7
  354. package/skills/agent-commerce.md +106 -0
  355. package/skills/browser-navigation.md +117 -0
  356. package/skills/commerce-setup-guide.md +116 -0
  357. package/skills/commerce-setup.md +84 -0
  358. package/skills/configure-dev-tools.md +101 -0
  359. package/skills/travel-planning.md +138 -0
  360. package/dist/heart/daemon/ouro-path-installer.js +0 -178
  361. package/dist/heart/daemon/subagent-installer.js +0 -166
  362. package/dist/heart/session-recall.js +0 -116
  363. package/dist/mind/associative-recall.js +0 -209
  364. package/dist/senses/bluebubbles-entry.js +0 -13
  365. package/dist/senses/bluebubbles.js +0 -1177
  366. package/dist/senses/debug-activity.js +0 -148
  367. package/subagents/README.md +0 -86
  368. package/subagents/work-doer.md +0 -237
  369. package/subagents/work-merger.md +0 -618
  370. package/subagents/work-planner.md +0 -390
  371. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  372. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  373. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  374. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  375. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  376. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  377. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  378. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  379. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  380. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  381. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  382. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  383. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  384. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  385. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  386. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
@@ -0,0 +1,683 @@
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._senseTurnCommandTimeoutMs = exports._senseTurnRetryDelays = exports.SENSE_TURN_COMMAND_TIMEOUT_MS = exports.SENSE_TURN_RETRY_DELAYS_MS = exports.SENSE_TURN_MAX_RETRIES = void 0;
37
+ exports._setSenseTurnRetryDelays = _setSenseTurnRetryDelays;
38
+ exports._setSenseTurnCommandTimeoutMs = _setSenseTurnCommandTimeoutMs;
39
+ exports.createMcpServer = createMcpServer;
40
+ exports.getToolSchemas = getToolSchemas;
41
+ const socket_client_1 = require("../daemon/socket-client");
42
+ const agentService = __importStar(require("../daemon/agent-service"));
43
+ const runtime_1 = require("../../nerves/runtime");
44
+ const session_id_resolver_1 = require("../daemon/session-id-resolver");
45
+ const pending_1 = require("../../mind/pending");
46
+ exports.SENSE_TURN_MAX_RETRIES = 3;
47
+ exports.SENSE_TURN_RETRY_DELAYS_MS = [1000, 2000, 4000];
48
+ exports.SENSE_TURN_COMMAND_TIMEOUT_MS = 10 * 60 * 1000;
49
+ // Allow test override
50
+ exports._senseTurnRetryDelays = exports.SENSE_TURN_RETRY_DELAYS_MS;
51
+ function _setSenseTurnRetryDelays(delays) { exports._senseTurnRetryDelays = delays; }
52
+ exports._senseTurnCommandTimeoutMs = exports.SENSE_TURN_COMMAND_TIMEOUT_MS;
53
+ function _setSenseTurnCommandTimeoutMs(timeoutMs) { exports._senseTurnCommandTimeoutMs = timeoutMs; }
54
+ async function withSenseTurnTimeout(promise, timeoutMs, command) {
55
+ let timer = null;
56
+ try {
57
+ return await Promise.race([
58
+ promise,
59
+ new Promise((_, reject) => {
60
+ timer = setTimeout(() => {
61
+ const error = new Error(`MCP send_message to ${command.agent} timed out after ${timeoutMs}ms waiting for daemon response; command status is unknown.`);
62
+ (0, runtime_1.emitNervesEvent)({
63
+ level: "error",
64
+ component: "daemon",
65
+ event: "daemon.mcp_sense_turn_timeout",
66
+ message: "MCP senseTurn timed out waiting for daemon response",
67
+ meta: { agent: command.agent, friendId: command.friendId, sessionKey: command.sessionKey, timeoutMs },
68
+ });
69
+ reject(error);
70
+ }, timeoutMs);
71
+ }),
72
+ ]);
73
+ }
74
+ finally {
75
+ /* v8 ignore next -- Promise.race installs the timer synchronously; null is only a defensive cleanup guard @preserve */
76
+ if (timer)
77
+ clearTimeout(timer);
78
+ }
79
+ }
80
+ /**
81
+ * Send a senseTurn command to the daemon with retry logic.
82
+ * Retries on transient failures: empty response (daemon mid-restart),
83
+ * ECONNREFUSED (daemon not yet listening), ENOENT (socket not yet created).
84
+ */
85
+ async function sendSenseTurnWithRetry(socketPath, command) {
86
+ let lastError = null;
87
+ /* v8 ignore start -- retry loop: functionally tested via mcp-send-message retry tests @preserve */
88
+ for (let attempt = 0; attempt <= exports.SENSE_TURN_MAX_RETRIES; attempt++) {
89
+ try {
90
+ const response = await withSenseTurnTimeout((0, socket_client_1.sendDaemonCommand)(socketPath, command), exports._senseTurnCommandTimeoutMs, command);
91
+ return response;
92
+ }
93
+ catch (error) {
94
+ lastError = error instanceof Error ? error : new Error(String(error));
95
+ const msg = lastError.message;
96
+ const isTransient = msg.includes("ECONNREFUSED")
97
+ || msg.includes("ENOENT")
98
+ || msg.includes("empty response")
99
+ || msg.includes("Empty response");
100
+ if (!isTransient || attempt >= exports.SENSE_TURN_MAX_RETRIES) {
101
+ throw lastError;
102
+ }
103
+ const delay = exports._senseTurnRetryDelays[attempt] ?? 4000;
104
+ (0, runtime_1.emitNervesEvent)({
105
+ component: "daemon",
106
+ event: "daemon.mcp_sense_turn_retry",
107
+ message: `senseTurn attempt ${attempt + 1} failed, retrying in ${delay}ms`,
108
+ meta: { attempt: attempt + 1, error: msg, delay },
109
+ });
110
+ await new Promise((resolve) => setTimeout(resolve, delay));
111
+ }
112
+ }
113
+ throw lastError ?? new Error("senseTurn failed after retries");
114
+ /* v8 ignore stop */
115
+ }
116
+ /**
117
+ * Maps MCP tool names to daemon command kinds.
118
+ */
119
+ const TOOL_TO_COMMAND = {
120
+ ask: "agent.ask",
121
+ status: "agent.status",
122
+ catchup: "agent.catchup",
123
+ delegate: "agent.delegate",
124
+ get_context: "agent.getContext",
125
+ search_notes: "agent.searchNotes",
126
+ get_task: "agent.getTask",
127
+ check_scope: "agent.checkScope",
128
+ request_decision: "agent.requestDecision",
129
+ check_guidance: "agent.checkGuidance",
130
+ report_progress: "agent.reportProgress",
131
+ report_blocker: "agent.reportBlocker",
132
+ report_complete: "agent.reportComplete",
133
+ };
134
+ /**
135
+ * Create an MCP server that speaks JSON-RPC 2.0 over stdio.
136
+ * Handles initialize, initialized, tools/list, and tools/call.
137
+ * Forwards tool calls to the daemon via Unix socket.
138
+ */
139
+ function createMcpServer(options) {
140
+ const { agent, friendId, socketPath, stdin, stdout } = options;
141
+ let buffer = "";
142
+ let running = false;
143
+ let useContentLengthFraming = true; // default to Content-Length, auto-detect from first message
144
+ // Resolve session ID once per MCP server instance for conversation continuity
145
+ const sessionId = (0, session_id_resolver_1.resolveSessionId)();
146
+ function writeResponse(response) {
147
+ const body = JSON.stringify(response);
148
+ if (useContentLengthFraming) {
149
+ const header = `Content-Length: ${Buffer.byteLength(body)}\r\n\r\n`;
150
+ stdout.write(header + body);
151
+ }
152
+ else {
153
+ stdout.write(body + "\n");
154
+ }
155
+ }
156
+ function tryParseContentLength() {
157
+ const headerEnd = buffer.indexOf("\r\n\r\n");
158
+ /* v8 ignore start -- partial header delivery only in real I/O */
159
+ if (headerEnd === -1)
160
+ return false;
161
+ /* v8 ignore stop */
162
+ const headerSection = buffer.slice(0, headerEnd);
163
+ const contentLengthMatch = headerSection.match(/Content-Length:\s*(\d+)/i);
164
+ if (!contentLengthMatch) {
165
+ buffer = buffer.slice(headerEnd + 4);
166
+ return true; // consumed invalid header, try again
167
+ }
168
+ const contentLength = parseInt(contentLengthMatch[1], 10);
169
+ const bodyStart = headerEnd + 4;
170
+ /* v8 ignore start -- partial body delivery only in real I/O */
171
+ if (buffer.length < bodyStart + contentLength)
172
+ return false;
173
+ /* v8 ignore stop */
174
+ const body = buffer.slice(bodyStart, bodyStart + contentLength);
175
+ buffer = buffer.slice(bodyStart + contentLength);
176
+ parseAndDispatch(body);
177
+ return true;
178
+ }
179
+ function tryParseNewlineDelimited() {
180
+ const newlineIdx = buffer.indexOf("\n");
181
+ /* v8 ignore start -- partial line delivery only in real I/O */
182
+ if (newlineIdx === -1)
183
+ return false;
184
+ /* v8 ignore stop */
185
+ const line = buffer.slice(0, newlineIdx).trim();
186
+ buffer = buffer.slice(newlineIdx + 1);
187
+ if (line.length === 0)
188
+ return true; // skip blank lines
189
+ parseAndDispatch(line);
190
+ return true;
191
+ }
192
+ function parseAndDispatch(body) {
193
+ let request;
194
+ try {
195
+ request = JSON.parse(body);
196
+ }
197
+ catch {
198
+ writeResponse({
199
+ jsonrpc: "2.0",
200
+ id: null,
201
+ error: { code: -32700, message: "Parse error" },
202
+ });
203
+ return;
204
+ }
205
+ void handleRequest(request);
206
+ }
207
+ let framingDetected = false;
208
+ function handleData(chunk) {
209
+ buffer += chunk.toString("utf-8");
210
+ // Auto-detect framing from first message and mirror it in responses
211
+ if (!framingDetected && buffer.length > 0) {
212
+ useContentLengthFraming = buffer.startsWith("Content-Length:");
213
+ framingDetected = true;
214
+ }
215
+ // Support both Content-Length framing (Claude Code) and newline-delimited JSON (Codex)
216
+ while (buffer.length > 0) {
217
+ const hasContentLength = buffer.startsWith("Content-Length:");
218
+ const parsed = hasContentLength ? tryParseContentLength() : tryParseNewlineDelimited();
219
+ /* v8 ignore start -- break on partial message only in real I/O */
220
+ if (!parsed)
221
+ break;
222
+ /* v8 ignore stop */
223
+ }
224
+ }
225
+ async function handleRequest(request) {
226
+ (0, runtime_1.emitNervesEvent)({
227
+ component: "daemon",
228
+ event: "daemon.mcp_request_start",
229
+ message: "handling MCP request",
230
+ meta: { method: request.method, agent },
231
+ });
232
+ // Notifications (no id) don't get responses
233
+ if (request.id === undefined) {
234
+ (0, runtime_1.emitNervesEvent)({
235
+ component: "daemon",
236
+ event: "daemon.mcp_request_end",
237
+ message: "handled MCP notification",
238
+ meta: { method: request.method, agent },
239
+ });
240
+ return;
241
+ }
242
+ switch (request.method) {
243
+ case "initialize":
244
+ await handleInitialize(request);
245
+ break;
246
+ case "tools/list":
247
+ handleToolsList(request);
248
+ break;
249
+ case "tools/call":
250
+ await handleToolsCall(request);
251
+ break;
252
+ default:
253
+ writeResponse({
254
+ jsonrpc: "2.0",
255
+ id: request.id,
256
+ error: {
257
+ code: -32601,
258
+ message: `Method not found: ${request.method}`,
259
+ },
260
+ });
261
+ break;
262
+ }
263
+ (0, runtime_1.emitNervesEvent)({
264
+ component: "daemon",
265
+ event: "daemon.mcp_request_end",
266
+ message: "completed MCP request",
267
+ meta: { method: request.method, agent },
268
+ });
269
+ }
270
+ async function handleInitialize(request) {
271
+ // MCP server works standalone (agent-service reads filesystem directly)
272
+ // Daemon is optional — only needed for commands without a direct service handler
273
+ writeResponse({
274
+ jsonrpc: "2.0",
275
+ id: request.id,
276
+ result: {
277
+ protocolVersion: "2024-11-05",
278
+ serverInfo: {
279
+ name: "ouro-mcp-server",
280
+ version: "0.1.0",
281
+ },
282
+ capabilities: {
283
+ tools: { listChanged: false },
284
+ },
285
+ },
286
+ });
287
+ }
288
+ function handleToolsList(request) {
289
+ const tools = getToolSchemas();
290
+ writeResponse({
291
+ jsonrpc: "2.0",
292
+ id: request.id,
293
+ result: { tools },
294
+ });
295
+ }
296
+ /** Map tool name → agent-service handler function name */
297
+ const TOOL_TO_SERVICE = {
298
+ ask: "handleAgentAsk",
299
+ status: "handleAgentStatus",
300
+ catchup: "handleAgentCatchup",
301
+ delegate: "handleAgentDelegate",
302
+ get_context: "handleAgentGetContext",
303
+ search_notes: "handleAgentSearchNotes",
304
+ get_task: "handleAgentGetTask",
305
+ check_scope: "handleAgentCheckScope",
306
+ request_decision: "handleAgentRequestDecision",
307
+ check_guidance: "handleAgentCheckGuidance",
308
+ report_progress: "handleAgentReportProgress",
309
+ report_blocker: "handleAgentReportBlocker",
310
+ report_complete: "handleAgentReportComplete",
311
+ };
312
+ async function handleToolsCall(request) {
313
+ /* v8 ignore start — ?? fallbacks are defensive; MCP clients always send params */
314
+ const params = request.params ?? {};
315
+ const toolName = params.name;
316
+ const toolArgs = (params.arguments ?? {});
317
+ /* v8 ignore stop */
318
+ // ── Conversation tools: send_message, check_response ──
319
+ if (toolName === "send_message") {
320
+ /* v8 ignore start — ?? fallback defensive; MCP clients always send message */
321
+ const message = toolArgs.message ?? "";
322
+ /* v8 ignore stop */
323
+ try {
324
+ const response = await sendSenseTurnWithRetry(socketPath, {
325
+ kind: "agent.senseTurn",
326
+ agent,
327
+ friendId,
328
+ channel: "mcp",
329
+ sessionKey: sessionId,
330
+ message,
331
+ });
332
+ /* v8 ignore next -- branch: ?? fallback for empty daemon response @preserve */
333
+ const text = response.message ?? "(empty response)";
334
+ writeResponse({
335
+ jsonrpc: "2.0",
336
+ id: request.id,
337
+ result: {
338
+ content: [{ type: "text", text }],
339
+ isError: !response.ok,
340
+ },
341
+ });
342
+ }
343
+ catch (error) {
344
+ /* v8 ignore start — instanceof guard defensive; thrown errors are always Error */
345
+ const errorMessage = error instanceof Error ? error.message : String(error);
346
+ /* v8 ignore stop */
347
+ /* v8 ignore start -- daemon-down detection: only triggers with real socket I/O @preserve */
348
+ const isDaemonDown = errorMessage.includes("ECONNREFUSED") || errorMessage.includes("ENOENT");
349
+ const userMessage = isDaemonDown
350
+ ? "The daemon is not running. Start it with `ouro up` (production) or `ouro dev` (development), then retry."
351
+ : `Error: ${errorMessage}`;
352
+ /* v8 ignore stop */
353
+ writeResponse({
354
+ jsonrpc: "2.0",
355
+ id: request.id,
356
+ result: {
357
+ content: [{ type: "text", text: userMessage }],
358
+ isError: true,
359
+ },
360
+ });
361
+ }
362
+ return;
363
+ }
364
+ if (toolName === "check_response") {
365
+ const pendingDir = (0, pending_1.getPendingDir)(agent, friendId, "mcp", sessionId);
366
+ const pending = (0, pending_1.drainPending)(pendingDir);
367
+ if (pending.length === 0) {
368
+ writeResponse({
369
+ jsonrpc: "2.0",
370
+ id: request.id,
371
+ result: {
372
+ content: [{ type: "text", text: "no pending messages" }],
373
+ isError: false,
374
+ },
375
+ });
376
+ }
377
+ else {
378
+ const text = pending.map((m) => m.content).join("\n\n---\n\n");
379
+ writeResponse({
380
+ jsonrpc: "2.0",
381
+ id: request.id,
382
+ result: {
383
+ content: [{ type: "text", text }],
384
+ isError: false,
385
+ },
386
+ });
387
+ }
388
+ return;
389
+ }
390
+ // ── delegate: full conversation turn via daemon ──
391
+ if (toolName === "delegate") {
392
+ /* v8 ignore start — ?? fallback defensive; MCP clients always send task */
393
+ const task = toolArgs.task ?? "";
394
+ /* v8 ignore stop */
395
+ const context = toolArgs.context;
396
+ const delegateMessage = context ? `[delegate] ${task}\n\ncontext: ${context}` : `[delegate] ${task}`;
397
+ try {
398
+ const response = await sendSenseTurnWithRetry(socketPath, {
399
+ kind: "agent.senseTurn",
400
+ agent,
401
+ friendId,
402
+ channel: "mcp",
403
+ sessionKey: sessionId,
404
+ message: delegateMessage,
405
+ });
406
+ /* v8 ignore next -- branch: ?? fallback for empty daemon response @preserve */
407
+ const text = response.message ?? "(empty response)";
408
+ writeResponse({
409
+ jsonrpc: "2.0",
410
+ id: request.id,
411
+ result: {
412
+ content: [{ type: "text", text }],
413
+ isError: !response.ok,
414
+ },
415
+ });
416
+ }
417
+ catch (error) {
418
+ /* v8 ignore start — instanceof guard defensive; thrown errors are always Error */
419
+ const errorMessage = error instanceof Error ? error.message : String(error);
420
+ /* v8 ignore stop */
421
+ /* v8 ignore start -- daemon-down detection: only triggers with real socket I/O @preserve */
422
+ const isDaemonDown = errorMessage.includes("ECONNREFUSED") || errorMessage.includes("ENOENT");
423
+ const userMessage = isDaemonDown
424
+ ? "The daemon is not running. Start it with `ouro up` (production) or `ouro dev` (development), then retry."
425
+ : `Error: ${errorMessage}`;
426
+ /* v8 ignore stop */
427
+ writeResponse({
428
+ jsonrpc: "2.0",
429
+ id: request.id,
430
+ result: {
431
+ content: [{ type: "text", text: userMessage }],
432
+ isError: true,
433
+ },
434
+ });
435
+ }
436
+ return;
437
+ }
438
+ // ── Legacy daemon/service tools ──
439
+ const commandKind = TOOL_TO_COMMAND[toolName];
440
+ if (!commandKind) {
441
+ writeResponse({
442
+ jsonrpc: "2.0",
443
+ id: request.id,
444
+ result: {
445
+ content: [{ type: "text", text: `Unknown tool: ${toolName}` }],
446
+ isError: true,
447
+ },
448
+ });
449
+ return;
450
+ }
451
+ // Call agent-service directly (no daemon roundtrip needed for read-only ops)
452
+ const serviceHandler = TOOL_TO_SERVICE[toolName];
453
+ let response;
454
+ /* v8 ignore start — typeof guard always true; instanceof check defensive; else branch unreachable for known tools */
455
+ if (serviceHandler && typeof agentService[serviceHandler] === "function") {
456
+ const handlerFn = agentService[serviceHandler];
457
+ try {
458
+ response = await handlerFn({ agent, friendId, socketPath, ...toolArgs });
459
+ }
460
+ catch (error) {
461
+ const errorMessage = error instanceof Error ? error.message : String(error);
462
+ response = { ok: false, error: `Service error: ${errorMessage}` };
463
+ }
464
+ }
465
+ else {
466
+ try {
467
+ response = await (0, socket_client_1.sendDaemonCommand)(socketPath, {
468
+ kind: commandKind, agent, friendId, ...toolArgs,
469
+ });
470
+ }
471
+ catch (error) {
472
+ const errorMessage = error instanceof Error ? error.message : String(error);
473
+ response = { ok: false, error: `Daemon error: ${errorMessage}` };
474
+ }
475
+ }
476
+ /* v8 ignore stop */
477
+ const text = response.message
478
+ ?? response.summary
479
+ ?? JSON.stringify(response.data ?? { ok: response.ok });
480
+ writeResponse({
481
+ jsonrpc: "2.0",
482
+ id: request.id,
483
+ result: {
484
+ content: [{ type: "text", text }],
485
+ isError: !response.ok,
486
+ },
487
+ });
488
+ }
489
+ function onData(chunk) {
490
+ handleData(chunk);
491
+ }
492
+ return {
493
+ agent,
494
+ friendId,
495
+ start() {
496
+ if (running)
497
+ return;
498
+ running = true;
499
+ stdin.on("data", onData);
500
+ (0, runtime_1.emitNervesEvent)({
501
+ component: "daemon",
502
+ event: "daemon.mcp_server_start",
503
+ message: "MCP server started",
504
+ meta: { agent, friendId, socketPath },
505
+ });
506
+ },
507
+ stop() {
508
+ if (!running)
509
+ return;
510
+ running = false;
511
+ stdin.removeListener("data", onData);
512
+ // `_end` (not `_stop`) to satisfy the nerves audit's start/end
513
+ // pairing rule — counterpart to `daemon.mcp_server_start`.
514
+ (0, runtime_1.emitNervesEvent)({
515
+ component: "daemon",
516
+ event: "daemon.mcp_server_end",
517
+ message: "MCP server stopped",
518
+ meta: { agent, friendId },
519
+ });
520
+ },
521
+ };
522
+ }
523
+ /**
524
+ * Returns the list of MCP tool schemas for all 15 agent tools.
525
+ * Each schema follows JSON Schema for inputSchema as required by MCP.
526
+ */
527
+ function getToolSchemas() {
528
+ return [
529
+ {
530
+ name: "ask",
531
+ description: "Ask the agent a question. The agent uses its diary, journal, and recent session context to provide a useful answer.",
532
+ inputSchema: {
533
+ type: "object",
534
+ properties: {
535
+ question: { type: "string", description: "The question to ask the agent" },
536
+ },
537
+ required: ["question"],
538
+ },
539
+ },
540
+ {
541
+ name: "status",
542
+ description: "Get the agent's current status including active sessions, diary and journal state, and activity level.",
543
+ inputSchema: {
544
+ type: "object",
545
+ properties: {},
546
+ },
547
+ },
548
+ {
549
+ name: "catchup",
550
+ description: "Get a summary of the agent's recent activity including recent sessions and what it has been working on.",
551
+ inputSchema: {
552
+ type: "object",
553
+ properties: {},
554
+ },
555
+ },
556
+ {
557
+ name: "delegate",
558
+ description: "Request the agent to handle a task. The agent queues the task and will work on it when available.",
559
+ inputSchema: {
560
+ type: "object",
561
+ properties: {
562
+ task: { type: "string", description: "Description of the task to delegate" },
563
+ context: { type: "string", description: "Additional context about the task" },
564
+ },
565
+ required: ["task"],
566
+ },
567
+ },
568
+ {
569
+ name: "get_context",
570
+ description: "Get the agent's current working context including note summary, active tasks, and relevant state.",
571
+ inputSchema: {
572
+ type: "object",
573
+ properties: {},
574
+ },
575
+ },
576
+ {
577
+ name: "search_notes",
578
+ description: "Search the agent's diary for information about a specific topic. Returns matching diary lines.",
579
+ inputSchema: {
580
+ type: "object",
581
+ properties: {
582
+ query: { type: "string", description: "Search term to look for in agent notes" },
583
+ },
584
+ required: ["query"],
585
+ },
586
+ },
587
+ {
588
+ name: "get_task",
589
+ description: "Get details about the agent's current task or list of active tasks.",
590
+ inputSchema: {
591
+ type: "object",
592
+ properties: {},
593
+ },
594
+ },
595
+ {
596
+ name: "check_scope",
597
+ description: "Check whether a proposed item or change is in scope for the agent's current work.",
598
+ inputSchema: {
599
+ type: "object",
600
+ properties: {
601
+ item: { type: "string", description: "The item or change to check scope for" },
602
+ },
603
+ required: ["item"],
604
+ },
605
+ },
606
+ {
607
+ name: "request_decision",
608
+ description: "Ask the agent to make a decision about a topic. Optionally provide a list of options to choose from.",
609
+ inputSchema: {
610
+ type: "object",
611
+ properties: {
612
+ topic: { type: "string", description: "The topic requiring a decision" },
613
+ options: { type: "string", description: "Comma-separated list of options to consider" },
614
+ },
615
+ required: ["topic"],
616
+ },
617
+ },
618
+ {
619
+ name: "check_guidance",
620
+ description: "Get guidance from the agent on how to approach a topic. The agent searches its diary, journal, and session context for relevant guidance.",
621
+ inputSchema: {
622
+ type: "object",
623
+ properties: {
624
+ topic: { type: "string", description: "The topic to get guidance on" },
625
+ },
626
+ required: ["topic"],
627
+ },
628
+ },
629
+ {
630
+ name: "report_progress",
631
+ description: "Report progress on delegated work back to the agent. The agent records the update.",
632
+ inputSchema: {
633
+ type: "object",
634
+ properties: {
635
+ summary: { type: "string", description: "Summary of progress made" },
636
+ },
637
+ required: ["summary"],
638
+ },
639
+ },
640
+ {
641
+ name: "report_blocker",
642
+ description: "Report a blocker on delegated work to the agent. The agent records the blocker for review.",
643
+ inputSchema: {
644
+ type: "object",
645
+ properties: {
646
+ blocker: { type: "string", description: "Description of the blocker" },
647
+ },
648
+ required: ["blocker"],
649
+ },
650
+ },
651
+ {
652
+ name: "report_complete",
653
+ description: "Report completion of delegated work to the agent. The agent records the completion.",
654
+ inputSchema: {
655
+ type: "object",
656
+ properties: {
657
+ summary: { type: "string", description: "Summary of what was completed" },
658
+ },
659
+ required: ["summary"],
660
+ },
661
+ },
662
+ {
663
+ name: "send_message",
664
+ description: "Send a message to the agent and get a synchronous response. This runs a full agent turn — the agent can use tools, think, and respond. For multi-turn conversations, call repeatedly — the agent keeps prior turns in this session.",
665
+ inputSchema: {
666
+ type: "object",
667
+ properties: {
668
+ message: { type: "string", description: "The message to send to the agent" },
669
+ },
670
+ required: ["message"],
671
+ },
672
+ },
673
+ {
674
+ name: "check_response",
675
+ description: "Check for pending messages from the agent. Use this after send_message returns a ponder deferral, or to pick up proactive messages the agent has surfaced to you.",
676
+ inputSchema: {
677
+ type: "object",
678
+ properties: {},
679
+ },
680
+ },
681
+ ];
682
+ }
683
+ // MCP server v0.1.0-alpha.140