@ouro.bot/cli 0.1.0-alpha.36 → 0.1.0-alpha.361

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 (326) hide show
  1. package/README.md +194 -184
  2. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +3 -2
  3. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +1 -1
  4. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  5. package/changelog.json +2155 -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 +832 -0
  16. package/dist/heart/agent-entry.js +37 -2
  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 +463 -0
  28. package/dist/heart/bridges/manager.js +358 -0
  29. package/dist/heart/bridges/state-machine.js +135 -0
  30. package/dist/heart/bridges/store.js +123 -0
  31. package/dist/heart/bundle-state.js +168 -0
  32. package/dist/heart/commitments.js +111 -0
  33. package/dist/heart/config-registry.js +304 -0
  34. package/dist/heart/config.js +53 -21
  35. package/dist/heart/core.js +743 -252
  36. package/dist/heart/cross-chat-delivery.js +131 -0
  37. package/dist/heart/daemon/agent-config-check.js +561 -0
  38. package/dist/heart/daemon/agent-discovery.js +79 -3
  39. package/dist/heart/daemon/agent-service.js +360 -0
  40. package/dist/heart/daemon/agentic-repair.js +185 -0
  41. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  42. package/dist/heart/daemon/cadence.js +70 -0
  43. package/dist/heart/daemon/cli-defaults.js +591 -0
  44. package/dist/heart/daemon/cli-exec.js +2649 -0
  45. package/dist/heart/daemon/cli-help.js +306 -0
  46. package/dist/heart/daemon/cli-parse.js +913 -0
  47. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  48. package/dist/heart/daemon/cli-render.js +560 -0
  49. package/dist/heart/daemon/cli-types.js +8 -0
  50. package/dist/heart/daemon/daemon-cli.js +30 -1171
  51. package/dist/heart/daemon/daemon-entry.js +358 -3
  52. package/dist/heart/daemon/daemon-health.js +141 -0
  53. package/dist/heart/daemon/daemon-runtime-sync.js +157 -12
  54. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  55. package/dist/heart/daemon/daemon.js +757 -58
  56. package/dist/heart/daemon/doctor-types.js +8 -0
  57. package/dist/heart/daemon/doctor.js +465 -0
  58. package/dist/heart/daemon/health-monitor.js +79 -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/inner-status.js +89 -0
  63. package/dist/heart/daemon/interactive-repair.js +91 -0
  64. package/dist/heart/daemon/launchd.js +46 -9
  65. package/dist/heart/daemon/log-tailer.js +82 -12
  66. package/dist/heart/daemon/logs-prune.js +105 -0
  67. package/dist/heart/daemon/message-router.js +17 -8
  68. package/dist/heart/daemon/os-cron-deps.js +134 -0
  69. package/dist/heart/daemon/ouro-bot-entry.js +1 -1
  70. package/dist/heart/daemon/process-manager.js +201 -0
  71. package/dist/heart/daemon/provider-discovery.js +140 -0
  72. package/dist/heart/daemon/pulse.js +475 -0
  73. package/dist/heart/daemon/run-hooks.js +2 -0
  74. package/dist/heart/daemon/runtime-logging.js +67 -16
  75. package/dist/heart/daemon/runtime-metadata.js +101 -0
  76. package/dist/heart/daemon/runtime-mode.js +67 -0
  77. package/dist/heart/daemon/safe-mode.js +161 -0
  78. package/dist/heart/daemon/sense-manager.js +72 -3
  79. package/dist/heart/daemon/session-id-resolver.js +131 -0
  80. package/dist/heart/daemon/skill-management-installer.js +94 -0
  81. package/dist/heart/daemon/socket-client.js +307 -0
  82. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  83. package/dist/heart/daemon/startup-tui.js +237 -0
  84. package/dist/heart/daemon/task-scheduler.js +3 -25
  85. package/dist/heart/daemon/thoughts.js +510 -0
  86. package/dist/heart/daemon/up-progress.js +135 -0
  87. package/dist/heart/delegation.js +62 -0
  88. package/dist/heart/habits/habit-migration.js +181 -0
  89. package/dist/heart/habits/habit-parser.js +140 -0
  90. package/dist/heart/habits/habit-scheduler.js +371 -0
  91. package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -120
  92. package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
  93. package/dist/heart/{daemon → hatch}/specialist-prompt.js +10 -7
  94. package/dist/heart/{daemon → hatch}/specialist-tools.js +56 -10
  95. package/dist/heart/identity.js +154 -59
  96. package/dist/heart/kept-notes.js +357 -0
  97. package/dist/heart/kicks.js +2 -20
  98. package/dist/heart/machine-identity.js +161 -0
  99. package/dist/heart/mcp/mcp-server.js +653 -0
  100. package/dist/heart/migrate-config.js +127 -0
  101. package/dist/heart/model-capabilities.js +59 -0
  102. package/dist/heart/outlook/outlook-http-hooks.js +64 -0
  103. package/dist/heart/outlook/outlook-http-response.js +7 -0
  104. package/dist/heart/outlook/outlook-http-routes.js +232 -0
  105. package/dist/heart/outlook/outlook-http-static.js +99 -0
  106. package/dist/heart/outlook/outlook-http-transport.js +116 -0
  107. package/dist/heart/outlook/outlook-http.js +99 -0
  108. package/dist/heart/outlook/outlook-read.js +28 -0
  109. package/dist/heart/outlook/outlook-types.js +27 -0
  110. package/dist/heart/outlook/outlook-view.js +195 -0
  111. package/dist/heart/outlook/readers/agent-machine.js +359 -0
  112. package/dist/heart/outlook/readers/continuity-readers.js +332 -0
  113. package/dist/heart/outlook/readers/runtime-readers.js +660 -0
  114. package/dist/heart/outlook/readers/sessions.js +232 -0
  115. package/dist/heart/outlook/readers/shared.js +111 -0
  116. package/dist/heart/progress-story.js +42 -0
  117. package/dist/heart/provider-attempt.js +133 -0
  118. package/dist/heart/provider-binding-resolver.js +240 -0
  119. package/dist/heart/provider-credential-pool.js +395 -0
  120. package/dist/heart/provider-failover.js +274 -0
  121. package/dist/heart/provider-models.js +81 -0
  122. package/dist/heart/provider-ping.js +227 -0
  123. package/dist/heart/provider-state.js +208 -0
  124. package/dist/heart/provider-visibility.js +183 -0
  125. package/dist/heart/providers/anthropic-token.js +163 -0
  126. package/dist/heart/providers/anthropic.js +177 -50
  127. package/dist/heart/providers/azure.js +102 -11
  128. package/dist/heart/providers/error-classification.js +63 -0
  129. package/dist/heart/providers/github-copilot.js +145 -0
  130. package/dist/heart/providers/minimax-vlm.js +189 -0
  131. package/dist/heart/providers/minimax.js +28 -6
  132. package/dist/heart/providers/openai-codex.js +38 -23
  133. package/dist/heart/session-activity.js +190 -0
  134. package/dist/heart/session-events.js +855 -0
  135. package/dist/heart/session-transcript.js +167 -0
  136. package/dist/heart/start-of-turn-packet.js +345 -0
  137. package/dist/heart/streaming.js +36 -27
  138. package/dist/heart/sync.js +332 -0
  139. package/dist/heart/target-resolution.js +127 -0
  140. package/dist/heart/tempo.js +93 -0
  141. package/dist/heart/temporal-view.js +41 -0
  142. package/dist/heart/tool-activity-callbacks.js +36 -0
  143. package/dist/heart/tool-description.js +135 -0
  144. package/dist/heart/tool-friction.js +55 -0
  145. package/dist/heart/tool-loop.js +200 -0
  146. package/dist/heart/turn-context.js +362 -0
  147. package/dist/heart/turn-coordinator.js +28 -0
  148. package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +1 -1
  149. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  150. package/dist/heart/versioning/ouro-path-installer.js +296 -0
  151. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  152. package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
  153. package/dist/heart/{daemon → versioning}/update-checker.js +12 -2
  154. package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
  155. package/dist/mind/bundle-manifest.js +7 -1
  156. package/dist/mind/context.js +141 -94
  157. package/dist/mind/diary-integrity.js +60 -0
  158. package/dist/mind/{memory.js → diary.js} +84 -96
  159. package/dist/mind/embedding-provider.js +60 -0
  160. package/dist/mind/file-state.js +179 -0
  161. package/dist/mind/first-impressions.js +14 -1
  162. package/dist/mind/friends/channel.js +56 -0
  163. package/dist/mind/friends/group-context.js +144 -0
  164. package/dist/mind/friends/resolver.js +38 -1
  165. package/dist/mind/friends/store-file.js +58 -3
  166. package/dist/mind/friends/trust-explanation.js +74 -0
  167. package/dist/mind/friends/types.js +9 -1
  168. package/dist/mind/journal-index.js +161 -0
  169. package/dist/mind/note-search.js +268 -0
  170. package/dist/mind/obligation-steering.js +221 -0
  171. package/dist/mind/pending.js +74 -7
  172. package/dist/mind/prompt.js +1013 -112
  173. package/dist/mind/provenance-trust.js +26 -0
  174. package/dist/mind/scrutiny.js +173 -0
  175. package/dist/mind/token-estimate.js +8 -12
  176. package/dist/nerves/cli-logging.js +7 -1
  177. package/dist/nerves/coverage/audit-rules.js +15 -6
  178. package/dist/nerves/coverage/audit.js +28 -2
  179. package/dist/nerves/coverage/cli.js +1 -1
  180. package/dist/nerves/coverage/file-completeness.js +83 -5
  181. package/dist/nerves/coverage/run-artifacts.js +1 -1
  182. package/dist/nerves/event-buffer.js +111 -0
  183. package/dist/nerves/index.js +224 -4
  184. package/dist/nerves/observation.js +20 -0
  185. package/dist/nerves/redact.js +79 -0
  186. package/dist/nerves/runtime.js +5 -1
  187. package/dist/outlook-ui/assets/index-LwChZTgL.css +1 -0
  188. package/dist/outlook-ui/assets/index-xTdv64BV.js +61 -0
  189. package/dist/outlook-ui/index.html +15 -0
  190. package/dist/repertoire/ado-client.js +15 -56
  191. package/dist/repertoire/ado-semantic.js +11 -10
  192. package/dist/repertoire/api-client.js +97 -0
  193. package/dist/repertoire/bitwarden-store.js +319 -0
  194. package/dist/repertoire/bundle-templates.js +72 -0
  195. package/dist/repertoire/bw-installer.js +79 -0
  196. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  197. package/dist/repertoire/coding/context-pack.js +330 -0
  198. package/dist/repertoire/coding/feedback.js +197 -30
  199. package/dist/repertoire/coding/manager.js +158 -9
  200. package/dist/repertoire/coding/spawner.js +55 -9
  201. package/dist/repertoire/coding/tools.js +170 -7
  202. package/dist/repertoire/commerce-errors.js +109 -0
  203. package/dist/repertoire/commerce-self-test.js +156 -0
  204. package/dist/repertoire/credential-access.js +527 -0
  205. package/dist/repertoire/duffel-client.js +185 -0
  206. package/dist/repertoire/github-client.js +14 -55
  207. package/dist/repertoire/graph-client.js +11 -52
  208. package/dist/repertoire/guardrails.js +375 -0
  209. package/dist/repertoire/mcp-client.js +255 -0
  210. package/dist/repertoire/mcp-manager.js +305 -0
  211. package/dist/repertoire/mcp-tools.js +63 -0
  212. package/dist/repertoire/shell-sessions.js +133 -0
  213. package/dist/repertoire/skills.js +15 -24
  214. package/dist/repertoire/stripe-client.js +131 -0
  215. package/dist/repertoire/tasks/board.js +43 -5
  216. package/dist/repertoire/tasks/fix.js +182 -0
  217. package/dist/repertoire/tasks/index.js +28 -10
  218. package/dist/repertoire/tasks/lifecycle.js +2 -2
  219. package/dist/repertoire/tasks/parser.js +3 -2
  220. package/dist/repertoire/tasks/scanner.js +194 -37
  221. package/dist/repertoire/tasks/transitions.js +16 -79
  222. package/dist/repertoire/tool-results.js +29 -0
  223. package/dist/repertoire/tools-attachments.js +316 -0
  224. package/dist/repertoire/tools-base.js +45 -771
  225. package/dist/repertoire/tools-bluebubbles.js +1 -0
  226. package/dist/repertoire/tools-bridge.js +141 -0
  227. package/dist/repertoire/tools-bundle.js +984 -0
  228. package/dist/repertoire/tools-config.js +185 -0
  229. package/dist/repertoire/tools-continuity.js +248 -0
  230. package/dist/repertoire/tools-credential.js +182 -0
  231. package/dist/repertoire/tools-files.js +342 -0
  232. package/dist/repertoire/tools-flight.js +224 -0
  233. package/dist/repertoire/tools-flow.js +105 -0
  234. package/dist/repertoire/tools-github.js +1 -7
  235. package/dist/repertoire/tools-notes.js +376 -0
  236. package/dist/repertoire/tools-session.js +739 -0
  237. package/dist/repertoire/tools-shell.js +120 -0
  238. package/dist/repertoire/tools-stripe.js +180 -0
  239. package/dist/repertoire/tools-surface.js +243 -0
  240. package/dist/repertoire/tools-teams.js +12 -62
  241. package/dist/repertoire/tools-travel.js +125 -0
  242. package/dist/repertoire/tools-user-profile.js +144 -0
  243. package/dist/repertoire/tools-vault.js +110 -0
  244. package/dist/repertoire/tools.js +144 -138
  245. package/dist/repertoire/travel-api-client.js +360 -0
  246. package/dist/repertoire/user-profile.js +118 -0
  247. package/dist/repertoire/vault-setup.js +241 -0
  248. package/dist/scripts/claude-code-hook.js +41 -0
  249. package/dist/scripts/claude-code-stop-hook.js +47 -0
  250. package/dist/senses/attention-queue.js +116 -0
  251. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  252. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  253. package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +225 -9
  254. package/dist/senses/bluebubbles/entry.js +13 -0
  255. package/dist/senses/bluebubbles/inbound-log.js +113 -0
  256. package/dist/senses/bluebubbles/index.js +1620 -0
  257. package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
  258. package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +43 -12
  259. package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +46 -6
  260. package/dist/senses/bluebubbles/replay.js +129 -0
  261. package/dist/senses/bluebubbles/runtime-state.js +109 -0
  262. package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
  263. package/dist/senses/cli/bracketed-paste.js +82 -0
  264. package/dist/senses/cli/image-paste.js +287 -0
  265. package/dist/senses/cli/image-ref-navigation.js +75 -0
  266. package/dist/senses/cli/ink-app.js +156 -0
  267. package/dist/senses/cli/inline-diff.js +64 -0
  268. package/dist/senses/cli/input-keys.js +174 -0
  269. package/dist/senses/cli/kill-ring.js +86 -0
  270. package/dist/senses/cli/message-list.js +51 -0
  271. package/dist/senses/cli/ouro-tui.js +605 -0
  272. package/dist/senses/cli/spinner-imperative.js +135 -0
  273. package/dist/senses/cli/spinner.js +101 -0
  274. package/dist/senses/cli/status-line.js +60 -0
  275. package/dist/senses/cli/streaming-markdown.js +526 -0
  276. package/dist/senses/cli/tool-display.js +83 -0
  277. package/dist/senses/cli/tool-render.js +85 -0
  278. package/dist/senses/cli/tui-store.js +240 -0
  279. package/dist/senses/cli/virtual-list.js +35 -0
  280. package/dist/senses/cli-entry.js +1 -1
  281. package/dist/senses/cli-layout.js +187 -0
  282. package/dist/senses/cli.js +587 -249
  283. package/dist/senses/commands.js +66 -3
  284. package/dist/senses/continuity.js +94 -0
  285. package/dist/senses/habit-turn-message.js +108 -0
  286. package/dist/senses/inner-dialog-worker.js +112 -19
  287. package/dist/senses/inner-dialog.js +636 -86
  288. package/dist/senses/pipeline.js +603 -0
  289. package/dist/senses/proactive-content-guard.js +51 -0
  290. package/dist/senses/shared-turn.js +205 -0
  291. package/dist/senses/surface-tool.js +68 -0
  292. package/dist/senses/teams.js +693 -160
  293. package/dist/senses/trust-gate.js +112 -2
  294. package/package.json +29 -7
  295. package/skills/agent-commerce.md +106 -0
  296. package/skills/browser-navigation.md +110 -0
  297. package/skills/commerce-setup-guide.md +116 -0
  298. package/skills/commerce-setup.md +84 -0
  299. package/skills/configure-dev-tools.md +81 -0
  300. package/skills/travel-planning.md +138 -0
  301. package/dist/heart/daemon/ouro-path-installer.js +0 -178
  302. package/dist/heart/daemon/subagent-installer.js +0 -134
  303. package/dist/mind/associative-recall.js +0 -197
  304. package/dist/senses/bluebubbles-entry.js +0 -11
  305. package/dist/senses/bluebubbles.js +0 -558
  306. package/dist/senses/debug-activity.js +0 -127
  307. package/subagents/README.md +0 -73
  308. package/subagents/work-doer.md +0 -235
  309. package/subagents/work-merger.md +0 -618
  310. package/subagents/work-planner.md +0 -382
  311. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  312. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  313. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  314. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  315. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  316. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
  317. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  318. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  319. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  320. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  321. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  322. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
  323. /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
  324. /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
  325. /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
  326. /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
@@ -3,24 +3,13 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.teamsToolHandlers = exports.teamsTools = exports.teamsToolDefinitions = void 0;
7
- exports.summarizeTeamsArgs = summarizeTeamsArgs;
6
+ exports.teamsToolDefinitions = void 0;
8
7
  const graph_client_1 = require("./graph-client");
9
8
  const ado_client_1 = require("./ado-client");
10
9
  const graph_endpoints_json_1 = __importDefault(require("./data/graph-endpoints.json"));
11
10
  const ado_endpoints_json_1 = __importDefault(require("./data/ado-endpoints.json"));
12
11
  const runtime_1 = require("../nerves/runtime");
13
12
  const MUTATE_METHODS = ["POST", "PATCH", "DELETE"];
14
- // Map HTTP method to authority action name for canWrite() checks
15
- const METHOD_TO_ACTION = {
16
- POST: "createWorkItem",
17
- PATCH: "updateWorkItem",
18
- DELETE: "deleteWorkItem",
19
- };
20
- // Check if a tool response indicates a 403 PERMISSION_DENIED (authority checker removed; this is now a no-op kept for call-site stability)
21
- function checkAndRecord403(_result, _integration, _scope, _action, _ctx) {
22
- // No-op: AuthorityChecker eliminated. 403 recording removed.
23
- }
24
13
  const DEFAULT_ADO_QUERY = "SELECT [System.Id], [System.Title], [System.State], [System.AssignedTo] FROM WorkItems WHERE [System.AssignedTo] = @Me AND [System.State] <> 'Closed' ORDER BY [System.ChangedDate] DESC";
25
14
  exports.teamsToolDefinitions = [
26
15
  // -- Generic Graph tools --
@@ -46,6 +35,7 @@ exports.teamsToolDefinitions = [
46
35
  return (0, graph_client_1.graphRequest)(ctx.graphToken, "GET", args.path);
47
36
  },
48
37
  integration: "graph",
38
+ summaryKeys: ["path"],
49
39
  },
50
40
  {
51
41
  tool: {
@@ -74,7 +64,7 @@ exports.teamsToolDefinitions = [
74
64
  return (0, graph_client_1.graphRequest)(ctx.graphToken, args.method, args.path, args.body);
75
65
  },
76
66
  integration: "graph",
77
- confirmationRequired: true,
67
+ summaryKeys: ["method", "path"],
78
68
  },
79
69
  // -- Generic ADO tools --
80
70
  {
@@ -101,11 +91,10 @@ exports.teamsToolDefinitions = [
101
91
  return "AUTH_REQUIRED:ado -- I need access to Azure DevOps. Please sign in when prompted.";
102
92
  }
103
93
  const method = args.method || "GET";
104
- const result = await (0, ado_client_1.adoRequest)(ctx.adoToken, method, args.organization, args.path, args.body, args.host);
105
- checkAndRecord403(result, "ado", args.organization, method, ctx);
106
- return result;
94
+ return (0, ado_client_1.adoRequest)(ctx.adoToken, method, args.organization, args.path, args.body, args.host);
107
95
  },
108
96
  integration: "ado",
97
+ summaryKeys: ["method", "organization", "path"],
109
98
  },
110
99
  {
111
100
  tool: {
@@ -133,14 +122,10 @@ exports.teamsToolDefinitions = [
133
122
  if (!MUTATE_METHODS.includes(args.method)) {
134
123
  return `Invalid method "${args.method}". Must be one of: ${MUTATE_METHODS.join(", ")}`;
135
124
  }
136
- /* v8 ignore next -- fallback unreachable: method is validated against MUTATE_METHODS above @preserve */
137
- const action = METHOD_TO_ACTION[args.method] || args.method;
138
- const result = await (0, ado_client_1.adoRequest)(ctx.adoToken, args.method, args.organization, args.path, args.body, args.host);
139
- checkAndRecord403(result, "ado", args.organization, action, ctx);
140
- return result;
125
+ return (0, ado_client_1.adoRequest)(ctx.adoToken, args.method, args.organization, args.path, args.body, args.host);
141
126
  },
142
127
  integration: "ado",
143
- confirmationRequired: true,
128
+ summaryKeys: ["method", "organization", "path"],
144
129
  },
145
130
  // -- Convenience aliases (backward compat) --
146
131
  {
@@ -159,6 +144,7 @@ exports.teamsToolDefinitions = [
159
144
  return (0, graph_client_1.getProfile)(ctx.graphToken);
160
145
  },
161
146
  integration: "graph",
147
+ summaryKeys: [],
162
148
  },
163
149
  {
164
150
  tool: {
@@ -202,6 +188,7 @@ exports.teamsToolDefinitions = [
202
188
  return (0, ado_client_1.queryWorkItems)(ctx.adoToken, org, query);
203
189
  },
204
190
  integration: "ado",
191
+ summaryKeys: ["organization", "query"],
205
192
  },
206
193
  // -- Proactive messaging --
207
194
  {
@@ -248,7 +235,7 @@ exports.teamsToolDefinitions = [
248
235
  }
249
236
  },
250
237
  /* v8 ignore stop */
251
- confirmationRequired: true,
238
+ summaryKeys: ["user_name", "user_id"],
252
239
  },
253
240
  // -- Documentation tools --
254
241
  {
@@ -270,6 +257,7 @@ exports.teamsToolDefinitions = [
270
257
  return searchEndpoints(graph_endpoints_json_1.default, args.query || "");
271
258
  },
272
259
  integration: "graph",
260
+ summaryKeys: ["query"],
273
261
  },
274
262
  {
275
263
  tool: {
@@ -290,12 +278,9 @@ exports.teamsToolDefinitions = [
290
278
  return searchEndpoints(ado_endpoints_json_1.default, args.query || "");
291
279
  },
292
280
  integration: "ado",
281
+ summaryKeys: ["query"],
293
282
  },
294
283
  ];
295
- // Backward-compat: extract just the OpenAI tool schemas
296
- exports.teamsTools = exports.teamsToolDefinitions.map((d) => d.tool);
297
- // Backward-compat: extract just the handlers by name
298
- exports.teamsToolHandlers = Object.fromEntries(exports.teamsToolDefinitions.map((d) => [d.tool.function.name, d.handler]));
299
284
  function searchEndpoints(entries, query) {
300
285
  (0, runtime_1.emitNervesEvent)({
301
286
  component: "repertoire",
@@ -324,38 +309,3 @@ function searchEndpoints(entries, query) {
324
309
  return lines.join("\n");
325
310
  }).join("\n\n");
326
311
  }
327
- function summarizeTeamsArgs(name, args) {
328
- function summarizeKeyValues(keys) {
329
- const parts = [];
330
- for (const key of keys) {
331
- const raw = args[key];
332
- if (raw === undefined || raw === null)
333
- continue;
334
- const compact = String(raw).replace(/\s+/g, " ").trim();
335
- if (!compact)
336
- continue;
337
- const clipped = compact.length > 60 ? compact.slice(0, 60) + "..." : compact;
338
- parts.push(`${key}=${clipped}`);
339
- }
340
- return parts.join(" ");
341
- }
342
- if (name === "graph_profile")
343
- return "";
344
- if (name === "ado_work_items")
345
- return summarizeKeyValues(["organization", "query"]);
346
- if (name === "graph_query")
347
- return summarizeKeyValues(["path"]);
348
- if (name === "graph_mutate")
349
- return summarizeKeyValues(["method", "path"]);
350
- if (name === "ado_query")
351
- return summarizeKeyValues(["method", "organization", "path"]);
352
- if (name === "ado_mutate")
353
- return summarizeKeyValues(["method", "organization", "path"]);
354
- if (name === "graph_docs")
355
- return summarizeKeyValues(["query"]);
356
- if (name === "ado_docs")
357
- return summarizeKeyValues(["query"]);
358
- if (name === "teams_send_message")
359
- return summarizeKeyValues(["user_name", "user_id"]);
360
- return undefined;
361
- }
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.travelToolDefinitions = void 0;
4
+ const travel_api_client_1 = require("./travel-api-client");
5
+ const runtime_1 = require("../nerves/runtime");
6
+ exports.travelToolDefinitions = [
7
+ {
8
+ tool: {
9
+ type: "function",
10
+ function: {
11
+ name: "weather_lookup",
12
+ description: "Get current weather for a location. Provide either a city name or lat/lon coordinates.",
13
+ parameters: {
14
+ type: "object",
15
+ properties: {
16
+ city: { type: "string", description: "City name (e.g. 'London', 'New York')" },
17
+ lat: { type: "string", description: "Latitude (decimal)" },
18
+ lon: { type: "string", description: "Longitude (decimal)" },
19
+ },
20
+ },
21
+ },
22
+ },
23
+ handler: async (args) => {
24
+ (0, runtime_1.emitNervesEvent)({
25
+ component: "repertoire",
26
+ event: "repertoire.travel_tool_call",
27
+ message: "weather_lookup invoked",
28
+ meta: { tool: "weather_lookup" },
29
+ });
30
+ try {
31
+ if (args.city) {
32
+ const data = await (0, travel_api_client_1.getWeatherByCity)(args.city);
33
+ return JSON.stringify(data, null, 2);
34
+ }
35
+ if (args.lat && args.lon) {
36
+ const data = await (0, travel_api_client_1.getWeather)(parseFloat(args.lat), parseFloat(args.lon));
37
+ return JSON.stringify(data, null, 2);
38
+ }
39
+ return "Please provide either a city name or lat/lon coordinates.";
40
+ }
41
+ catch (err) {
42
+ /* v8 ignore next -- defensive: callers throw Error instances @preserve */
43
+ return `Weather lookup error: ${err instanceof Error ? err.message : String(err)}`;
44
+ }
45
+ },
46
+ summaryKeys: ["city", "lat", "lon"],
47
+ },
48
+ {
49
+ tool: {
50
+ type: "function",
51
+ function: {
52
+ name: "travel_advisory",
53
+ description: "Get US State Department travel advisory for a country. Returns advisory level (1-4) and description.",
54
+ parameters: {
55
+ type: "object",
56
+ properties: {
57
+ country_code: {
58
+ type: "string",
59
+ description: "ISO 3166 alpha-2 country code (e.g. 'US', 'GB', 'AF')",
60
+ },
61
+ },
62
+ required: ["country_code"],
63
+ },
64
+ },
65
+ },
66
+ handler: async (args) => {
67
+ (0, runtime_1.emitNervesEvent)({
68
+ component: "repertoire",
69
+ event: "repertoire.travel_tool_call",
70
+ message: "travel_advisory invoked",
71
+ meta: { tool: "travel_advisory" },
72
+ });
73
+ try {
74
+ const data = await (0, travel_api_client_1.getTravelAdvisory)(args.country_code.toUpperCase());
75
+ return JSON.stringify(data, null, 2);
76
+ }
77
+ catch (err) {
78
+ /* v8 ignore next -- defensive: callers throw Error instances @preserve */
79
+ return `Travel advisory error: ${err instanceof Error ? err.message : String(err)}`;
80
+ }
81
+ },
82
+ summaryKeys: ["country_code"],
83
+ },
84
+ {
85
+ tool: {
86
+ type: "function",
87
+ function: {
88
+ name: "geocode_search",
89
+ description: "Search for locations, addresses, or points of interest. Returns coordinates and display names.",
90
+ parameters: {
91
+ type: "object",
92
+ properties: {
93
+ query: { type: "string", description: "Search query (e.g. 'Eiffel Tower', '123 Main St')" },
94
+ near_lat: { type: "string", description: "Latitude to search near (for POI search)" },
95
+ near_lon: { type: "string", description: "Longitude to search near (for POI search)" },
96
+ radius_km: { type: "string", description: "Search radius in km (default 10)" },
97
+ },
98
+ required: ["query"],
99
+ },
100
+ },
101
+ },
102
+ handler: async (args) => {
103
+ (0, runtime_1.emitNervesEvent)({
104
+ component: "repertoire",
105
+ event: "repertoire.travel_tool_call",
106
+ message: "geocode_search invoked",
107
+ meta: { tool: "geocode_search" },
108
+ });
109
+ try {
110
+ if (args.near_lat && args.near_lon) {
111
+ const radiusKm = args.radius_km ? parseFloat(args.radius_km) : undefined;
112
+ const data = await (0, travel_api_client_1.searchPOI)(args.query, parseFloat(args.near_lat), parseFloat(args.near_lon), radiusKm);
113
+ return JSON.stringify(data, null, 2);
114
+ }
115
+ const data = await (0, travel_api_client_1.geocode)(args.query);
116
+ return JSON.stringify(data, null, 2);
117
+ }
118
+ catch (err) {
119
+ /* v8 ignore next -- defensive: callers throw Error instances @preserve */
120
+ return `Geocode error: ${err instanceof Error ? err.message : String(err)}`;
121
+ }
122
+ },
123
+ summaryKeys: ["query"],
124
+ },
125
+ ];
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.userProfileToolDefinitions = void 0;
4
+ const user_profile_1 = require("./user-profile");
5
+ const credential_access_1 = require("./credential-access");
6
+ const runtime_1 = require("../nerves/runtime");
7
+ function requireFamilyContext(ctx) {
8
+ if (!ctx?.context?.friend?.id) {
9
+ return "no friend context — cannot access user profile.";
10
+ }
11
+ if (ctx.context.friend.trustLevel !== "family") {
12
+ return "user profile access requires family trust level.";
13
+ }
14
+ return { friendId: ctx.context.friend.id };
15
+ }
16
+ exports.userProfileToolDefinitions = [
17
+ {
18
+ tool: {
19
+ type: "function",
20
+ function: {
21
+ name: "user_profile_store",
22
+ description: "Store or update user profile fields (legal name, DOB, passport, etc.) in the agent's vault. Fields are merged with any existing profile. Requires family trust level.",
23
+ parameters: {
24
+ type: "object",
25
+ properties: {
26
+ fields: {
27
+ type: "string",
28
+ description: 'JSON object with profile fields to store/update. Keys: legalName, dateOfBirth, gender, nationality, passport, driverLicense, email, phone, addresses, loyaltyPrograms, preferences, emergencyContact.',
29
+ },
30
+ },
31
+ required: ["fields"],
32
+ },
33
+ },
34
+ },
35
+ handler: async (args, ctx) => {
36
+ (0, runtime_1.emitNervesEvent)({
37
+ component: "repertoire",
38
+ event: "repertoire.tool_user_profile_store",
39
+ message: "user_profile_store invoked",
40
+ meta: { tool: "user_profile_store" },
41
+ });
42
+ const guard = requireFamilyContext(ctx);
43
+ if (typeof guard === "string")
44
+ return guard;
45
+ let fields;
46
+ try {
47
+ fields = JSON.parse(args.fields);
48
+ }
49
+ catch {
50
+ return "invalid JSON in fields parameter.";
51
+ }
52
+ try {
53
+ const store = (0, credential_access_1.getCredentialStore)();
54
+ await (0, user_profile_1.updateUserProfileFields)(guard.friendId, fields, store);
55
+ return `profile fields stored for ${guard.friendId}.`;
56
+ }
57
+ catch (err) {
58
+ /* v8 ignore next -- defensive: updateUserProfileFields errors are always Error instances @preserve */
59
+ return `failed to store profile: ${err instanceof Error ? err.message : String(err)}`;
60
+ }
61
+ },
62
+ summaryKeys: ["fields"],
63
+ },
64
+ {
65
+ tool: {
66
+ type: "function",
67
+ function: {
68
+ name: "user_profile_get",
69
+ description: "Retrieve a specific field from a user's profile. Only returns the requested field, never the full profile. Requires family trust level.",
70
+ parameters: {
71
+ type: "object",
72
+ properties: {
73
+ field: {
74
+ type: "string",
75
+ description: "The profile field to retrieve: legalName, dateOfBirth, gender, nationality, passport, driverLicense, email, phone, addresses, loyaltyPrograms, preferences, emergencyContact.",
76
+ },
77
+ },
78
+ required: ["field"],
79
+ },
80
+ },
81
+ },
82
+ handler: async (args, ctx) => {
83
+ (0, runtime_1.emitNervesEvent)({
84
+ component: "repertoire",
85
+ event: "repertoire.tool_user_profile_get",
86
+ message: "user_profile_get invoked",
87
+ meta: { tool: "user_profile_get", field: args.field },
88
+ });
89
+ const guard = requireFamilyContext(ctx);
90
+ if (typeof guard === "string")
91
+ return guard;
92
+ try {
93
+ const store = (0, credential_access_1.getCredentialStore)();
94
+ const value = await (0, user_profile_1.getUserProfileField)(guard.friendId, args.field, store);
95
+ if (value === undefined) {
96
+ return `field "${args.field}" is not set on the profile.`;
97
+ }
98
+ /* v8 ignore next -- platform-dependent v8 branch counting on ternary @preserve */
99
+ return typeof value === "string" ? value : JSON.stringify(value, null, 2);
100
+ }
101
+ catch (err) {
102
+ /* v8 ignore next -- defensive: getUserProfileField errors are always Error instances @preserve */
103
+ return `failed to get profile field: ${err instanceof Error ? err.message : String(err)}`;
104
+ }
105
+ },
106
+ summaryKeys: ["field"],
107
+ },
108
+ {
109
+ tool: {
110
+ type: "function",
111
+ function: {
112
+ name: "user_profile_delete",
113
+ description: "Delete a user's entire profile from the vault. This is irreversible. Requires family trust level.",
114
+ parameters: {
115
+ type: "object",
116
+ properties: {},
117
+ },
118
+ },
119
+ },
120
+ handler: async (_args, ctx) => {
121
+ (0, runtime_1.emitNervesEvent)({
122
+ component: "repertoire",
123
+ event: "repertoire.tool_user_profile_delete",
124
+ message: "user_profile_delete invoked",
125
+ meta: { tool: "user_profile_delete" },
126
+ });
127
+ const guard = requireFamilyContext(ctx);
128
+ if (typeof guard === "string")
129
+ return guard;
130
+ try {
131
+ const store = (0, credential_access_1.getCredentialStore)();
132
+ const deleted = await (0, user_profile_1.deleteUserProfile)(guard.friendId, store);
133
+ return deleted
134
+ ? `profile deleted for ${guard.friendId}.`
135
+ : `no profile found for ${guard.friendId}.`;
136
+ }
137
+ catch (err) {
138
+ /* v8 ignore next -- defensive: deleteUserProfile errors are always Error instances @preserve */
139
+ return `failed to delete profile: ${err instanceof Error ? err.message : String(err)}`;
140
+ }
141
+ },
142
+ summaryKeys: [],
143
+ },
144
+ ];
@@ -0,0 +1,110 @@
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.vaultToolDefinitions = void 0;
37
+ const crypto = __importStar(require("node:crypto"));
38
+ const fs = __importStar(require("node:fs"));
39
+ const path = __importStar(require("node:path"));
40
+ const identity_1 = require("../heart/identity");
41
+ const vault_setup_1 = require("./vault-setup");
42
+ const runtime_1 = require("../nerves/runtime");
43
+ exports.vaultToolDefinitions = [
44
+ {
45
+ tool: {
46
+ type: "function",
47
+ function: {
48
+ name: "vault_setup",
49
+ description: "Set up the agent's credential vault. Creates a Bitwarden account on the configured Vaultwarden server. One-time operation — idempotent if vault already exists.",
50
+ parameters: {
51
+ type: "object",
52
+ properties: {},
53
+ },
54
+ },
55
+ },
56
+ handler: async () => {
57
+ const agentName = (0, identity_1.getAgentName)();
58
+ (0, runtime_1.emitNervesEvent)({
59
+ component: "repertoire",
60
+ event: "repertoire.vault_tool_call",
61
+ message: "vault_setup invoked",
62
+ meta: { tool: "vault_setup", agentName },
63
+ });
64
+ try {
65
+ const config = (0, identity_1.loadAgentConfig)();
66
+ const { email, serverUrl } = (0, identity_1.resolveVaultConfig)(agentName, config.vault);
67
+ // Generate a strong random master password (32 bytes -> base64)
68
+ const masterPassword = crypto.randomBytes(32).toString("base64");
69
+ // Store master password in secrets.json BEFORE creating the account
70
+ // so it's not lost if the process crashes after registration
71
+ const secretsPath = (0, identity_1.getAgentSecretsPath)(agentName);
72
+ const secretsDir = path.dirname(secretsPath);
73
+ if (!fs.existsSync(secretsDir)) {
74
+ fs.mkdirSync(secretsDir, { recursive: true, mode: 0o700 });
75
+ }
76
+ let secrets = {};
77
+ if (fs.existsSync(secretsPath)) {
78
+ try {
79
+ secrets = JSON.parse(fs.readFileSync(secretsPath, "utf-8"));
80
+ }
81
+ catch {
82
+ // If secrets.json is corrupt, start fresh but don't lose the file
83
+ secrets = {};
84
+ }
85
+ }
86
+ secrets.vault = {
87
+ ...(typeof secrets.vault === "object" && secrets.vault !== null ? secrets.vault : {}),
88
+ masterPassword,
89
+ email,
90
+ serverUrl,
91
+ };
92
+ fs.writeFileSync(secretsPath, JSON.stringify(secrets, null, 2) + "\n", {
93
+ mode: 0o600,
94
+ });
95
+ // Create the vault account
96
+ const result = await (0, vault_setup_1.createVaultAccount)(agentName, serverUrl, email, masterPassword);
97
+ if (!result.success) {
98
+ return `Vault setup failed: ${result.error}`;
99
+ }
100
+ return `Vault created at ${serverUrl} for ${email}. Master password stored in secrets.json.`;
101
+ }
102
+ catch (err) {
103
+ /* v8 ignore next -- defensive: error handling @preserve */
104
+ const reason = err instanceof Error ? err.message : String(err);
105
+ return `Vault setup error: ${reason}`;
106
+ }
107
+ },
108
+ summaryKeys: [],
109
+ },
110
+ ];