@ouro.bot/cli 0.1.0-alpha.50 → 0.1.0-alpha.501

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 (369) hide show
  1. package/README.md +133 -19
  2. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +3 -2
  3. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
  4. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  5. package/changelog.json +3184 -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 +867 -35
  16. package/dist/heart/agent-entry.js +58 -3
  17. package/dist/heart/attachments/image-normalize.js +194 -0
  18. package/dist/heart/attachments/materialize.js +97 -0
  19. package/dist/heart/attachments/originals.js +88 -0
  20. package/dist/heart/attachments/render.js +29 -0
  21. package/dist/heart/attachments/sources/adapter.js +2 -0
  22. package/dist/heart/attachments/sources/bluebubbles.js +156 -0
  23. package/dist/heart/attachments/sources/cli-local-file.js +78 -0
  24. package/dist/heart/attachments/sources/index.js +16 -0
  25. package/dist/heart/attachments/store.js +103 -0
  26. package/dist/heart/attachments/types.js +93 -0
  27. package/dist/heart/auth/auth-flow.js +426 -0
  28. package/dist/heart/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 +898 -244
  34. package/dist/heart/cross-chat-delivery.js +131 -0
  35. package/dist/heart/daemon/agent-config-check.js +490 -0
  36. package/dist/heart/daemon/agent-discovery.js +79 -3
  37. package/dist/heart/daemon/agent-service.js +360 -0
  38. package/dist/heart/daemon/agentic-repair.js +216 -0
  39. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  40. package/dist/heart/daemon/cadence.js +70 -0
  41. package/dist/heart/daemon/cli-defaults.js +640 -0
  42. package/dist/heart/daemon/cli-exec.js +7239 -0
  43. package/dist/heart/daemon/cli-help.js +493 -0
  44. package/dist/heart/daemon/cli-parse.js +1533 -0
  45. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  46. package/dist/heart/daemon/cli-render.js +561 -0
  47. package/dist/heart/daemon/cli-types.js +8 -0
  48. package/dist/heart/daemon/connect-bay.js +323 -0
  49. package/dist/heart/daemon/daemon-cli.js +29 -1631
  50. package/dist/heart/daemon/daemon-entry.js +345 -3
  51. package/dist/heart/daemon/daemon-health.js +141 -0
  52. package/dist/heart/daemon/daemon-runtime-sync.js +190 -12
  53. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  54. package/dist/heart/daemon/daemon.js +677 -58
  55. package/dist/heart/daemon/dns-workflow.js +394 -0
  56. package/dist/heart/daemon/doctor-types.js +8 -0
  57. package/dist/heart/daemon/doctor.js +615 -0
  58. package/dist/heart/daemon/health-monitor.js +92 -1
  59. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  60. package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
  61. package/dist/heart/daemon/http-health-probe.js +80 -0
  62. package/dist/heart/daemon/human-command-screens.js +234 -0
  63. package/dist/heart/daemon/human-readiness.js +114 -0
  64. package/dist/heart/daemon/inner-status.js +89 -0
  65. package/dist/heart/daemon/interactive-repair.js +394 -0
  66. package/dist/heart/daemon/launchd.js +25 -5
  67. package/dist/heart/daemon/log-tailer.js +82 -12
  68. package/dist/heart/daemon/logs-prune.js +110 -0
  69. package/dist/heart/daemon/message-router.js +2 -2
  70. package/dist/heart/daemon/os-cron-deps.js +134 -0
  71. package/dist/heart/daemon/ouro-bot-entry.js +4 -2
  72. package/dist/heart/daemon/ouro-entry.js +3 -1
  73. package/dist/heart/daemon/process-manager.js +214 -0
  74. package/dist/heart/daemon/provider-discovery.js +137 -0
  75. package/dist/heart/daemon/provider-ping-progress.js +83 -0
  76. package/dist/heart/daemon/pulse.js +475 -0
  77. package/dist/heart/daemon/readiness-repair.js +365 -0
  78. package/dist/heart/daemon/run-hooks.js +2 -0
  79. package/dist/heart/daemon/runtime-logging.js +67 -16
  80. package/dist/heart/daemon/runtime-metadata.js +73 -0
  81. package/dist/heart/daemon/runtime-mode.js +67 -0
  82. package/dist/heart/daemon/safe-mode.js +161 -0
  83. package/dist/heart/daemon/sense-manager.js +178 -37
  84. package/dist/heart/daemon/session-id-resolver.js +131 -0
  85. package/dist/heart/daemon/skill-management-installer.js +94 -0
  86. package/dist/heart/daemon/socket-client.js +109 -4
  87. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  88. package/dist/heart/daemon/startup-tui.js +264 -0
  89. package/dist/heart/daemon/task-scheduler.js +3 -25
  90. package/dist/heart/daemon/terminal-ui.js +499 -0
  91. package/dist/heart/daemon/thoughts.js +162 -17
  92. package/dist/heart/daemon/up-progress.js +366 -0
  93. package/dist/heart/daemon/vault-items.js +56 -0
  94. package/dist/heart/delegation.js +1 -1
  95. package/dist/heart/habits/habit-migration.js +189 -0
  96. package/dist/heart/habits/habit-parser.js +140 -0
  97. package/dist/heart/habits/habit-runtime-state.js +100 -0
  98. package/dist/heart/habits/habit-scheduler.js +372 -0
  99. package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
  100. package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
  101. package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
  102. package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
  103. package/dist/heart/identity.js +201 -66
  104. package/dist/heart/kept-notes.js +357 -0
  105. package/dist/heart/kicks.js +1 -1
  106. package/dist/heart/machine-identity.js +161 -0
  107. package/dist/heart/mail-import-discovery.js +353 -0
  108. package/dist/heart/mcp/mcp-server.js +653 -0
  109. package/dist/heart/migrate-config.js +100 -0
  110. package/dist/heart/model-capabilities.js +59 -0
  111. package/dist/heart/outlook/outlook-http-hooks.js +66 -0
  112. package/dist/heart/outlook/outlook-http-response.js +7 -0
  113. package/dist/heart/outlook/outlook-http-routes.js +244 -0
  114. package/dist/heart/outlook/outlook-http-static.js +103 -0
  115. package/dist/heart/outlook/outlook-http-transport.js +116 -0
  116. package/dist/heart/outlook/outlook-http.js +99 -0
  117. package/dist/heart/outlook/outlook-read.js +31 -0
  118. package/dist/heart/outlook/outlook-types.js +27 -0
  119. package/dist/heart/outlook/outlook-view.js +195 -0
  120. package/dist/heart/outlook/readers/agent-machine.js +382 -0
  121. package/dist/heart/outlook/readers/continuity-readers.js +336 -0
  122. package/dist/heart/outlook/readers/mail.js +362 -0
  123. package/dist/heart/outlook/readers/runtime-readers.js +644 -0
  124. package/dist/heart/outlook/readers/sessions.js +232 -0
  125. package/dist/heart/outlook/readers/shared.js +111 -0
  126. package/dist/heart/platform.js +81 -0
  127. package/dist/heart/provider-attempt.js +134 -0
  128. package/dist/heart/provider-binding-resolver.js +255 -0
  129. package/dist/heart/provider-credentials.js +424 -0
  130. package/dist/heart/provider-failover.js +301 -0
  131. package/dist/heart/provider-models.js +81 -0
  132. package/dist/heart/provider-ping.js +262 -0
  133. package/dist/heart/provider-state.js +216 -0
  134. package/dist/heart/provider-visibility.js +188 -0
  135. package/dist/heart/providers/anthropic-token.js +131 -0
  136. package/dist/heart/providers/anthropic.js +193 -55
  137. package/dist/heart/providers/azure.js +104 -13
  138. package/dist/heart/providers/error-classification.js +63 -0
  139. package/dist/heart/providers/github-copilot.js +145 -0
  140. package/dist/heart/providers/minimax-vlm.js +189 -0
  141. package/dist/heart/providers/minimax.js +29 -7
  142. package/dist/heart/providers/openai-codex.js +63 -39
  143. package/dist/heart/runtime-capability-check.js +170 -0
  144. package/dist/heart/runtime-credentials.js +260 -0
  145. package/dist/heart/sense-truth.js +11 -4
  146. package/dist/heart/session-activity.js +43 -22
  147. package/dist/heart/session-events.js +1089 -0
  148. package/dist/heart/session-playback-cli-main.js +5 -0
  149. package/dist/heart/session-playback-cli.js +36 -0
  150. package/dist/heart/session-playback.js +231 -0
  151. package/dist/heart/session-transcript.js +167 -0
  152. package/dist/heart/start-of-turn-packet.js +345 -0
  153. package/dist/heart/streaming.js +48 -28
  154. package/dist/heart/sync.js +332 -0
  155. package/dist/heart/target-resolution.js +127 -0
  156. package/dist/heart/tempo.js +93 -0
  157. package/dist/heart/temporal-view.js +41 -0
  158. package/dist/heart/tool-activity-callbacks.js +36 -0
  159. package/dist/heart/tool-description.js +135 -0
  160. package/dist/heart/tool-friction.js +55 -0
  161. package/dist/heart/tool-loop.js +200 -0
  162. package/dist/heart/turn-context.js +372 -0
  163. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +1 -1
  164. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  165. package/dist/heart/versioning/ouro-path-installer.js +425 -0
  166. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  167. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  168. package/dist/heart/{daemon → versioning}/update-checker.js +5 -1
  169. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  170. package/dist/mailroom/attention.js +167 -0
  171. package/dist/mailroom/autonomy.js +209 -0
  172. package/dist/mailroom/blob-store.js +606 -0
  173. package/dist/mailroom/core.js +672 -0
  174. package/dist/mailroom/entry.js +160 -0
  175. package/dist/mailroom/file-store.js +426 -0
  176. package/dist/mailroom/mbox-import.js +382 -0
  177. package/dist/mailroom/outbound.js +380 -0
  178. package/dist/mailroom/policy.js +263 -0
  179. package/dist/mailroom/reader.js +219 -0
  180. package/dist/mailroom/search-cache.js +182 -0
  181. package/dist/mailroom/search-relevance.js +319 -0
  182. package/dist/mailroom/smtp-ingress.js +176 -0
  183. package/dist/mailroom/source-state.js +176 -0
  184. package/dist/mailroom/thread.js +109 -0
  185. package/dist/mailroom/travel-extract.js +89 -0
  186. package/dist/mind/bundle-manifest.js +7 -1
  187. package/dist/mind/context.js +164 -101
  188. package/dist/mind/diary-integrity.js +60 -0
  189. package/dist/mind/{memory.js → diary.js} +74 -93
  190. package/dist/mind/embedding-provider.js +60 -0
  191. package/dist/mind/file-state.js +179 -0
  192. package/dist/mind/friends/channel.js +30 -0
  193. package/dist/mind/friends/group-context.js +144 -0
  194. package/dist/mind/friends/resolver.js +54 -2
  195. package/dist/mind/friends/store-file.js +39 -3
  196. package/dist/mind/friends/trust-explanation.js +74 -0
  197. package/dist/mind/friends/types.js +2 -2
  198. package/dist/mind/journal-index.js +161 -0
  199. package/dist/mind/note-search.js +268 -0
  200. package/dist/mind/obligation-steering.js +221 -0
  201. package/dist/mind/pending.js +4 -0
  202. package/dist/mind/prompt-refresh.js +3 -2
  203. package/dist/mind/prompt.js +948 -110
  204. package/dist/mind/provenance-trust.js +26 -0
  205. package/dist/mind/scrutiny.js +173 -0
  206. package/dist/nerves/cli-logging.js +7 -1
  207. package/dist/nerves/coverage/audit-rules.js +15 -6
  208. package/dist/nerves/coverage/audit.js +28 -2
  209. package/dist/nerves/coverage/cli.js +1 -1
  210. package/dist/nerves/coverage/contract.js +5 -5
  211. package/dist/nerves/coverage/file-completeness.js +106 -5
  212. package/dist/nerves/coverage/run-artifacts.js +1 -1
  213. package/dist/nerves/event-buffer.js +111 -0
  214. package/dist/nerves/index.js +224 -4
  215. package/dist/nerves/observation.js +20 -0
  216. package/dist/nerves/redact.js +79 -0
  217. package/dist/nerves/review/cli-main.js +5 -0
  218. package/dist/nerves/review/cli.js +156 -0
  219. package/dist/nerves/review/core.js +152 -0
  220. package/dist/nerves/runtime.js +5 -1
  221. package/dist/outlook-ui/assets/index-BPr5vNuM.css +1 -0
  222. package/dist/outlook-ui/assets/index-Cm51CY9W.js +61 -0
  223. package/dist/outlook-ui/index.html +15 -0
  224. package/dist/repertoire/ado-client.js +15 -56
  225. package/dist/repertoire/ado-semantic.js +11 -10
  226. package/dist/repertoire/api-client.js +97 -0
  227. package/dist/repertoire/bitwarden-store.js +774 -0
  228. package/dist/repertoire/bundle-templates.js +72 -0
  229. package/dist/repertoire/bw-installer.js +180 -0
  230. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  231. package/dist/repertoire/coding/context-pack.js +330 -0
  232. package/dist/repertoire/coding/feedback.js +197 -30
  233. package/dist/repertoire/coding/manager.js +158 -9
  234. package/dist/repertoire/coding/spawner.js +55 -9
  235. package/dist/repertoire/coding/tools.js +170 -7
  236. package/dist/repertoire/commerce-errors.js +109 -0
  237. package/dist/repertoire/commerce-self-test.js +156 -0
  238. package/dist/repertoire/credential-access.js +111 -0
  239. package/dist/repertoire/duffel-client.js +185 -0
  240. package/dist/repertoire/github-client.js +14 -55
  241. package/dist/repertoire/graph-client.js +11 -52
  242. package/dist/repertoire/guardrails.js +396 -0
  243. package/dist/repertoire/mcp-client.js +255 -0
  244. package/dist/repertoire/mcp-manager.js +305 -0
  245. package/dist/repertoire/mcp-tools.js +63 -0
  246. package/dist/repertoire/shell-sessions.js +133 -0
  247. package/dist/repertoire/skills.js +15 -24
  248. package/dist/repertoire/stripe-client.js +131 -0
  249. package/dist/repertoire/tasks/board.js +31 -5
  250. package/dist/repertoire/tasks/fix.js +182 -0
  251. package/dist/repertoire/tasks/index.js +16 -4
  252. package/dist/repertoire/tasks/lifecycle.js +2 -2
  253. package/dist/repertoire/tasks/parser.js +3 -2
  254. package/dist/repertoire/tasks/scanner.js +194 -37
  255. package/dist/repertoire/tasks/transitions.js +16 -78
  256. package/dist/repertoire/tool-results.js +29 -0
  257. package/dist/repertoire/tools-attachments.js +317 -0
  258. package/dist/repertoire/tools-base.js +46 -921
  259. package/dist/repertoire/tools-bluebubbles.js +1 -0
  260. package/dist/repertoire/tools-bridge.js +141 -0
  261. package/dist/repertoire/tools-bundle.js +984 -0
  262. package/dist/repertoire/tools-config.js +185 -0
  263. package/dist/repertoire/tools-continuity.js +248 -0
  264. package/dist/repertoire/tools-credential.js +381 -0
  265. package/dist/repertoire/tools-files.js +342 -0
  266. package/dist/repertoire/tools-flight.js +224 -0
  267. package/dist/repertoire/tools-flow.js +105 -0
  268. package/dist/repertoire/tools-github.js +1 -7
  269. package/dist/repertoire/tools-mail.js +1377 -0
  270. package/dist/repertoire/tools-notes.js +376 -0
  271. package/dist/repertoire/tools-session.js +749 -0
  272. package/dist/repertoire/tools-shell.js +120 -0
  273. package/dist/repertoire/tools-stripe.js +180 -0
  274. package/dist/repertoire/tools-surface.js +243 -0
  275. package/dist/repertoire/tools-teams.js +9 -39
  276. package/dist/repertoire/tools-travel.js +125 -0
  277. package/dist/repertoire/tools-trip.js +356 -0
  278. package/dist/repertoire/tools-user-profile.js +144 -0
  279. package/dist/repertoire/tools-vault.js +40 -0
  280. package/dist/repertoire/tools.js +144 -115
  281. package/dist/repertoire/travel-api-client.js +360 -0
  282. package/dist/repertoire/user-profile.js +131 -0
  283. package/dist/repertoire/vault-setup.js +246 -0
  284. package/dist/repertoire/vault-unlock.js +561 -0
  285. package/dist/scripts/claude-code-hook.js +41 -0
  286. package/dist/scripts/claude-code-stop-hook.js +47 -0
  287. package/dist/senses/attention-queue.js +116 -0
  288. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  289. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  290. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
  291. package/dist/senses/bluebubbles/entry.js +73 -0
  292. package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
  293. package/dist/senses/bluebubbles/index.js +1881 -0
  294. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  295. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
  296. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
  297. package/dist/senses/bluebubbles/processed-log.js +111 -0
  298. package/dist/senses/bluebubbles/replay.js +129 -0
  299. package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +2 -2
  300. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  301. package/dist/senses/cli/bracketed-paste.js +82 -0
  302. package/dist/senses/cli/image-paste.js +287 -0
  303. package/dist/senses/cli/image-ref-navigation.js +75 -0
  304. package/dist/senses/cli/ink-app.js +156 -0
  305. package/dist/senses/cli/inline-diff.js +64 -0
  306. package/dist/senses/cli/input-keys.js +174 -0
  307. package/dist/senses/cli/kill-ring.js +86 -0
  308. package/dist/senses/cli/message-list.js +51 -0
  309. package/dist/senses/cli/ouro-tui.js +605 -0
  310. package/dist/senses/cli/spinner-imperative.js +135 -0
  311. package/dist/senses/cli/spinner.js +101 -0
  312. package/dist/senses/cli/status-line.js +60 -0
  313. package/dist/senses/cli/streaming-markdown.js +526 -0
  314. package/dist/senses/cli/tool-display.js +83 -0
  315. package/dist/senses/cli/tool-render.js +85 -0
  316. package/dist/senses/cli/tui-store.js +240 -0
  317. package/dist/senses/cli/virtual-list.js +35 -0
  318. package/dist/senses/cli-entry.js +60 -8
  319. package/dist/senses/cli-layout.js +187 -0
  320. package/dist/senses/cli.js +511 -209
  321. package/dist/senses/commands.js +66 -3
  322. package/dist/senses/habit-turn-message.js +108 -0
  323. package/dist/senses/inner-dialog-worker.js +175 -21
  324. package/dist/senses/inner-dialog.js +330 -27
  325. package/dist/senses/mail-entry.js +66 -0
  326. package/dist/senses/mail.js +379 -0
  327. package/dist/senses/pipeline.js +573 -164
  328. package/dist/senses/proactive-content-guard.js +51 -0
  329. package/dist/senses/shared-turn.js +248 -0
  330. package/dist/senses/surface-tool.js +68 -0
  331. package/dist/senses/teams-entry.js +60 -8
  332. package/dist/senses/teams.js +405 -170
  333. package/dist/senses/trust-gate.js +100 -5
  334. package/dist/trips/core.js +138 -0
  335. package/dist/trips/store.js +146 -0
  336. package/package.json +39 -8
  337. package/skills/agent-commerce.md +106 -0
  338. package/skills/browser-navigation.md +117 -0
  339. package/skills/commerce-setup-guide.md +116 -0
  340. package/skills/commerce-setup.md +84 -0
  341. package/skills/configure-dev-tools.md +101 -0
  342. package/skills/travel-planning.md +138 -0
  343. package/dist/heart/daemon/ouro-path-installer.js +0 -178
  344. package/dist/heart/daemon/subagent-installer.js +0 -166
  345. package/dist/heart/session-recall.js +0 -116
  346. package/dist/mind/associative-recall.js +0 -209
  347. package/dist/senses/bluebubbles-entry.js +0 -13
  348. package/dist/senses/bluebubbles.js +0 -1142
  349. package/dist/senses/debug-activity.js +0 -148
  350. package/subagents/README.md +0 -86
  351. package/subagents/work-doer.md +0 -237
  352. package/subagents/work-merger.md +0 -618
  353. package/subagents/work-planner.md +0 -390
  354. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  355. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  356. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  357. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  358. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  359. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  360. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  361. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  362. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  363. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  364. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  365. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  366. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  367. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  368. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  369. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
@@ -1,43 +1,52 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.REMOTE_BLOCKED_LOCAL_TOOLS = exports.finalAnswerTool = exports.tools = void 0;
3
+ exports.surfaceToolDef = exports.restTool = exports.ponderTool = exports.observeTool = exports.settleTool = exports.tools = void 0;
4
+ exports.resetMcpDefinitions = resetMcpDefinitions;
4
5
  exports.getToolsForChannel = getToolsForChannel;
5
- exports.isConfirmationRequired = isConfirmationRequired;
6
6
  exports.execTool = execTool;
7
7
  exports.summarizeArgs = summarizeArgs;
8
+ exports.buildToolResultSummary = buildToolResultSummary;
8
9
  const tools_base_1 = require("./tools-base");
9
10
  const tools_teams_1 = require("./tools-teams");
10
11
  const tools_bluebubbles_1 = require("./tools-bluebubbles");
11
12
  const ado_semantic_1 = require("./ado-semantic");
12
13
  const tools_github_1 = require("./tools-github");
13
- const types_1 = require("../mind/friends/types");
14
- const channel_1 = require("../mind/friends/channel");
14
+ const tools_bundle_1 = require("./tools-bundle");
15
15
  const runtime_1 = require("../nerves/runtime");
16
+ const guardrails_1 = require("./guardrails");
17
+ const identity_1 = require("../heart/identity");
18
+ const tools_surface_1 = require("./tools-surface");
19
+ const mcp_tools_1 = require("./mcp-tools");
20
+ function safeGetAgentRoot() {
21
+ try {
22
+ return (0, identity_1.getAgentRoot)();
23
+ }
24
+ catch {
25
+ return undefined;
26
+ }
27
+ }
16
28
  // Re-export types and constants used by the rest of the codebase
17
29
  var tools_base_2 = require("./tools-base");
18
30
  Object.defineProperty(exports, "tools", { enumerable: true, get: function () { return tools_base_2.tools; } });
19
- Object.defineProperty(exports, "finalAnswerTool", { enumerable: true, get: function () { return tools_base_2.finalAnswerTool; } });
31
+ Object.defineProperty(exports, "settleTool", { enumerable: true, get: function () { return tools_base_2.settleTool; } });
32
+ Object.defineProperty(exports, "observeTool", { enumerable: true, get: function () { return tools_base_2.observeTool; } });
33
+ Object.defineProperty(exports, "ponderTool", { enumerable: true, get: function () { return tools_base_2.ponderTool; } });
34
+ Object.defineProperty(exports, "restTool", { enumerable: true, get: function () { return tools_base_2.restTool; } });
35
+ // Re-export surface tool schema for consumers (e.g. heart/core.ts)
36
+ var tools_surface_2 = require("./tools-surface");
37
+ Object.defineProperty(exports, "surfaceToolDef", { enumerable: true, get: function () { return tools_surface_2.surfaceToolDef; } });
20
38
  // All tool definitions in a single registry
21
- const allDefinitions = [...tools_base_1.baseToolDefinitions, ...tools_bluebubbles_1.bluebubblesToolDefinitions, ...tools_teams_1.teamsToolDefinitions, ...ado_semantic_1.adoSemanticToolDefinitions, ...tools_github_1.githubToolDefinitions];
22
- /** Tool names blocked for untrusted remote contexts. Shared with prompt.ts for restriction messaging. */
23
- exports.REMOTE_BLOCKED_LOCAL_TOOLS = new Set(["shell", "read_file", "write_file", "edit_file", "glob", "grep"]);
24
- function isTrustedRemoteContext(context) {
25
- if (!context?.friend || !(0, channel_1.isRemoteChannel)(context.channel))
26
- return false;
27
- return (0, types_1.isTrustedLevel)(context.friend.trustLevel);
39
+ const allDefinitions = [...tools_base_1.baseToolDefinitions, ...tools_bluebubbles_1.bluebubblesToolDefinitions, ...tools_teams_1.teamsToolDefinitions, ...ado_semantic_1.adoSemanticToolDefinitions, ...tools_github_1.githubToolDefinitions, ...tools_bundle_1.bundleToolDefinitions, tools_surface_1.surfaceToolDefinition];
40
+ // MCP tool definitions populated each time getToolsForChannel() is called with an mcpManager.
41
+ // Kept separate from allDefinitions so execTool can find them.
42
+ let mcpDefinitions = [];
43
+ /** Exported for testing — reset the MCP definitions cache. */
44
+ function resetMcpDefinitions() {
45
+ mcpDefinitions = [];
28
46
  }
29
- function shouldBlockLocalTools(capabilities, context) {
30
- if (!(0, channel_1.isRemoteChannel)(capabilities))
31
- return false;
32
- return !isTrustedRemoteContext(context);
33
- }
34
- function blockedLocalToolMessage() {
35
- return "I can't do that because my trust level with you isn't high enough for local shell/file operations. Ask me for a remote-safe alternative (Graph/ADO/web), or run that operation from CLI.";
36
- }
37
- function baseToolsForCapabilities(capabilities, context) {
38
- if (!shouldBlockLocalTools(capabilities, context))
39
- return tools_base_1.tools;
40
- return tools_base_1.tools.filter((tool) => !exports.REMOTE_BLOCKED_LOCAL_TOOLS.has(tool.function.name));
47
+ function baseToolsForCapabilities() {
48
+ // Use baseToolDefinitions at call time so dynamically-added tools are included
49
+ return tools_base_1.baseToolDefinitions.map((d) => d.tool);
41
50
  }
42
51
  // Apply a single tool preference to a tool schema, returning a new object.
43
52
  function applyPreference(tool, pref) {
@@ -49,53 +58,79 @@ function applyPreference(tool, pref) {
49
58
  },
50
59
  };
51
60
  }
61
+ // Filter out tools whose requiredCapability is not in the provider's capability set.
62
+ // Uses baseToolDefinitions at call time so dynamically-added tools are included.
63
+ // Only base tools can have requiredCapability (integration tools do not).
64
+ function filterByCapability(toolList, providerCapabilities) {
65
+ return toolList.filter((tool) => {
66
+ const def = tools_base_1.baseToolDefinitions.find((d) => d.tool.function.name === tool.function.name);
67
+ if (!def?.requiredCapability)
68
+ return true;
69
+ return providerCapabilities?.has(def.requiredCapability) === true;
70
+ });
71
+ }
52
72
  // Return the appropriate tools list based on channel capabilities.
53
73
  // Base tools (no integration) are always included.
54
74
  // Teams/integration tools are included only if their integration is in availableIntegrations.
55
75
  // When toolPreferences is provided, matching preferences are appended to tool descriptions.
56
- function getToolsForChannel(capabilities, toolPreferences, context) {
57
- const baseTools = baseToolsForCapabilities(capabilities, context);
76
+ // When providerCapabilities is provided, tools with requiredCapability are filtered.
77
+ function getToolsForChannel(capabilities, toolPreferences, _context, providerCapabilities, mcpManager, _chatModel) {
78
+ const baseTools = baseToolsForCapabilities();
58
79
  const bluebubblesTools = capabilities?.channel === "bluebubbles"
59
80
  ? tools_bluebubbles_1.bluebubblesToolDefinitions.map((d) => d.tool)
60
81
  : [];
82
+ let result;
61
83
  if (!capabilities || capabilities.availableIntegrations.length === 0) {
62
- return [...baseTools, ...bluebubblesTools];
84
+ result = [...baseTools, ...bluebubblesTools];
63
85
  }
64
- const available = new Set(capabilities.availableIntegrations);
65
- const channelDefs = [...tools_teams_1.teamsToolDefinitions, ...ado_semantic_1.adoSemanticToolDefinitions, ...tools_github_1.githubToolDefinitions];
66
- // Include tools whose integration is available, plus channel tools with no integration gate (e.g. teams_send_message)
67
- const integrationDefs = channelDefs.filter((d) => d.integration ? available.has(d.integration) : capabilities.channel === "teams");
68
- if (!toolPreferences || Object.keys(toolPreferences).length === 0) {
69
- return [...baseTools, ...bluebubblesTools, ...integrationDefs.map((d) => d.tool)];
86
+ else {
87
+ const available = new Set(capabilities.availableIntegrations);
88
+ const channelDefs = [...tools_teams_1.teamsToolDefinitions, ...ado_semantic_1.adoSemanticToolDefinitions, ...tools_github_1.githubToolDefinitions];
89
+ // Include tools whose integration is available, plus channel tools with no integration gate (e.g. teams_send_message)
90
+ const integrationDefs = channelDefs.filter((d) => d.integration ? available.has(d.integration) : capabilities.channel === "teams");
91
+ if (!toolPreferences || Object.keys(toolPreferences).length === 0) {
92
+ result = [...baseTools, ...bluebubblesTools, ...integrationDefs.map((d) => d.tool)];
93
+ }
94
+ else {
95
+ // Build a map of integration -> preference text for fast lookup
96
+ const prefMap = new Map();
97
+ for (const [key, value] of Object.entries(toolPreferences)) {
98
+ prefMap.set(key, value);
99
+ }
100
+ // Apply preferences to matching integration tools (new objects, no mutation)
101
+ // d.integration is guaranteed truthy -- integrationDefs are pre-filtered above
102
+ const enrichedIntegrationTools = integrationDefs.map((d) => {
103
+ const pref = prefMap.get(d.integration);
104
+ return pref ? applyPreference(d.tool, pref) : d.tool;
105
+ });
106
+ result = [...baseTools, ...bluebubblesTools, ...enrichedIntegrationTools];
107
+ }
70
108
  }
71
- // Build a map of integration -> preference text for fast lookup
72
- const prefMap = new Map();
73
- for (const [key, value] of Object.entries(toolPreferences)) {
74
- prefMap.set(key, value);
109
+ // Append first-class MCP tools when mcpManager is provided
110
+ if (mcpManager) {
111
+ mcpDefinitions = (0, mcp_tools_1.mcpToolsAsDefinitions)(mcpManager);
112
+ const mcpSchemas = mcpDefinitions.map((d) => d.tool);
113
+ result = [...result, ...mcpSchemas];
75
114
  }
76
- // Apply preferences to matching integration tools (new objects, no mutation)
77
- // d.integration is guaranteed truthy -- integrationDefs are pre-filtered above
78
- const enrichedIntegrationTools = integrationDefs.map((d) => {
79
- const pref = prefMap.get(d.integration);
80
- return pref ? applyPreference(d.tool, pref) : d.tool;
81
- });
82
- return [...baseTools, ...bluebubblesTools, ...enrichedIntegrationTools];
115
+ return filterByCapability(result, providerCapabilities);
83
116
  }
84
- // Check whether a tool requires user confirmation before execution.
85
- // Reads from ToolDefinition.confirmationRequired instead of a separate Set.
86
- function isConfirmationRequired(toolName) {
87
- const def = allDefinitions.find((d) => d.tool.function.name === toolName);
88
- return def?.confirmationRequired === true;
117
+ // Look up a tool definition from the combined registry (native + MCP).
118
+ function findDefinition(toolName) {
119
+ return allDefinitions.find((d) => d.tool.function.name === toolName)
120
+ ?? mcpDefinitions.find((d) => d.tool.function.name === toolName);
121
+ }
122
+ function normalizeGuardArgs(_name, args) {
123
+ return args;
89
124
  }
90
125
  async function execTool(name, args, ctx) {
91
126
  (0, runtime_1.emitNervesEvent)({
92
127
  event: "tool.start",
93
128
  component: "tools",
94
129
  message: "tool execution started",
95
- meta: { name },
130
+ meta: { name, ...(name === "shell" && args.command ? { command: args.command } : {}) },
96
131
  });
97
- // Look up from combined registry
98
- const def = allDefinitions.find((d) => d.tool.function.name === name);
132
+ // Look up from combined registry (native + MCP)
133
+ const def = findDefinition(name);
99
134
  if (!def) {
100
135
  (0, runtime_1.emitNervesEvent)({
101
136
  level: "error",
@@ -106,16 +141,26 @@ async function execTool(name, args, ctx) {
106
141
  });
107
142
  return `unknown: ${name}`;
108
143
  }
109
- if (shouldBlockLocalTools(ctx?.context?.channel, ctx?.context) && exports.REMOTE_BLOCKED_LOCAL_TOOLS.has(name)) {
110
- const message = blockedLocalToolMessage();
144
+ // Guardrail check: structural + trust-level
145
+ const mcpDef = mcpDefinitions.find((d) => d.tool.function.name === name);
146
+ const guardContext = {
147
+ readPaths: tools_base_1.editFileReadTracker,
148
+ trustLevel: ctx?.context?.friend?.trustLevel,
149
+ agentRoot: safeGetAgentRoot(),
150
+ ...(mcpDef?.mcpServer ? { mcpServerName: mcpDef.mcpServer } : {}),
151
+ ...(ctx?.context?.isGroupChat !== undefined ? { isGroupChat: (ctx?.context).isGroupChat } : {}),
152
+ };
153
+ const guardArgs = normalizeGuardArgs(name, args);
154
+ const guardResult = (0, guardrails_1.guardInvocation)(name, guardArgs, guardContext);
155
+ if (!guardResult.allowed) {
111
156
  (0, runtime_1.emitNervesEvent)({
112
157
  level: "warn",
113
- event: "tool.error",
158
+ event: "tool.guardrail_block",
114
159
  component: "tools",
115
- message: "blocked local tool in remote channel",
116
- meta: { name, channel: ctx?.context?.channel?.channel },
160
+ message: "guardrail blocked tool execution",
161
+ meta: { name, reason: guardResult.reason },
117
162
  });
118
- return message;
163
+ return guardResult.reason;
119
164
  }
120
165
  try {
121
166
  const result = await def.handler(args, ctx);
@@ -159,63 +204,47 @@ function summarizeUnknownArgs(args) {
159
204
  return summarizeKeyValues(args, keys);
160
205
  }
161
206
  function summarizeArgs(name, args) {
162
- // Check teams tools first
163
- const teamsSummary = (0, tools_teams_1.summarizeTeamsArgs)(name, args);
164
- if (teamsSummary !== undefined)
165
- return teamsSummary;
166
- // Check github tools
167
- const githubSummary = (0, tools_github_1.summarizeGithubArgs)(name, args);
168
- if (githubSummary !== undefined)
169
- return githubSummary;
170
- // Base tools
171
- if (name === "read_file" || name === "write_file")
172
- return summarizeKeyValues(args, ["path"]);
173
- if (name === "edit_file")
174
- return summarizeKeyValues(args, ["path"]);
175
- if (name === "glob")
176
- return summarizeKeyValues(args, ["pattern", "cwd"]);
177
- if (name === "grep")
178
- return summarizeKeyValues(args, ["pattern", "path", "include"]);
179
- if (name === "shell")
180
- return summarizeKeyValues(args, ["command"]);
181
- if (name === "load_skill")
182
- return summarizeKeyValues(args, ["name"]);
183
- if (name === "coding_spawn")
184
- return summarizeKeyValues(args, ["runner", "workdir", "taskRef"]);
185
- if (name === "coding_status")
186
- return summarizeKeyValues(args, ["sessionId"]);
187
- if (name === "coding_tail")
188
- return summarizeKeyValues(args, ["sessionId"]);
189
- if (name === "coding_send_input")
190
- return summarizeKeyValues(args, ["sessionId", "input"]);
191
- if (name === "coding_kill")
192
- return summarizeKeyValues(args, ["sessionId"]);
193
- if (name === "bluebubbles_set_reply_target")
194
- return summarizeKeyValues(args, ["target", "threadOriginatorGuid"]);
195
- if (name === "claude")
196
- return summarizeKeyValues(args, ["prompt"]);
197
- if (name === "web_search")
198
- return summarizeKeyValues(args, ["query"]);
199
- if (name === "memory_search")
200
- return summarizeKeyValues(args, ["query"]);
201
- if (name === "memory_save")
202
- return summarizeKeyValues(args, ["text", "about"]);
203
- if (name === "get_friend_note")
204
- return summarizeKeyValues(args, ["friendId"]);
205
- if (name === "save_friend_note") {
206
- return summarizeKeyValues(args, ["type", "key", "content"]);
207
+ const def = findDefinition(name);
208
+ if (def && def.summaryKeys !== undefined) {
209
+ return summarizeKeyValues(args, def.summaryKeys);
207
210
  }
208
- if (name === "bridge_manage")
209
- return summarizeKeyValues(args, ["action", "bridgeId", "objective", "friendId", "channel", "key"]);
210
- if (name === "ado_backlog_list")
211
- return summarizeKeyValues(args, ["organization", "project"]);
212
- if (name === "ado_batch_update")
213
- return summarizeKeyValues(args, ["organization", "project"]);
214
- if (name === "ado_create_epic" || name === "ado_create_issue")
215
- return summarizeKeyValues(args, ["organization", "project", "title"]);
216
- if (name === "ado_move_items")
217
- return summarizeKeyValues(args, ["organization", "project", "workItemIds"]);
218
- if (name === "ado_restructure_backlog")
219
- return summarizeKeyValues(args, ["organization", "project"]);
220
211
  return summarizeUnknownArgs(args);
221
212
  }
213
+ /**
214
+ * Build an enriched tool result summary for display on remote channels.
215
+ * For recognized tools, includes result-derived info (diff stats, exit codes, etc.).
216
+ * Falls back to arg-based summary for unrecognized tools.
217
+ */
218
+ function buildToolResultSummary(name, args, _result, success) {
219
+ /* v8 ignore start -- branches: ?? fallbacks and ternaries in tool summary formatting @preserve */
220
+ switch (name) {
221
+ case "edit_file": {
222
+ if (!success)
223
+ return summarizeArgs(name, args);
224
+ const addedLines = (args.new_string ?? "").split("\n").length;
225
+ const removedLines = (args.old_string ?? "").split("\n").length;
226
+ return `+${addedLines} -${removedLines} lines in ${args.path ?? "unknown"}`;
227
+ }
228
+ case "shell": {
229
+ const cmd = args.command ?? "?";
230
+ const exitCode = success ? 0 : 1;
231
+ return `$ ${cmd} (exit ${exitCode})`;
232
+ }
233
+ case "read_file":
234
+ return `path=${args.path ?? "unknown"}`;
235
+ case "write_file":
236
+ return `path=${args.path ?? "unknown"}`;
237
+ case "glob":
238
+ return `pattern=${args.pattern ?? "?"} ${args.cwd ? `cwd=${args.cwd}` : ""}`.trim();
239
+ case "grep":
240
+ return `pattern=${args.pattern ?? "?"} ${args.path ? `path=${args.path}` : ""}`.trim();
241
+ case "coding_spawn": {
242
+ const taskRef = args.taskRef ?? "unknown";
243
+ const status = success ? "spawned" : "failed";
244
+ return `${taskRef} -> ${status}`;
245
+ }
246
+ default:
247
+ return summarizeArgs(name, args);
248
+ }
249
+ /* v8 ignore stop */
250
+ }