@ouro.bot/cli 0.1.0-alpha.65 → 0.1.0-alpha.651
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.
- package/README.md +127 -23
- package/RepairGuide.ouro/agent.json +5 -0
- package/RepairGuide.ouro/psyche/IDENTITY.md +19 -0
- package/RepairGuide.ouro/psyche/SOUL.md +55 -0
- package/RepairGuide.ouro/skills/diagnose-broken-remote.md +63 -0
- package/RepairGuide.ouro/skills/diagnose-stacked-typed-issues.md +35 -0
- package/RepairGuide.ouro/skills/diagnose-sync-blocked.md +54 -0
- package/RepairGuide.ouro/skills/diagnose-vault-expired.md +60 -0
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +4 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
- package/changelog.json +4157 -14
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +144 -0
- package/dist/arc/episodes.js +118 -0
- package/dist/arc/evolution.js +487 -0
- package/dist/arc/intentions.js +134 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +270 -0
- package/dist/arc/packets.js +288 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +57 -0
- package/dist/heart/active-work.js +860 -43
- package/dist/heart/agent-entry.js +69 -3
- package/dist/heart/attachments/image-normalize.js +194 -0
- package/dist/heart/attachments/materialize.js +97 -0
- package/dist/heart/attachments/originals.js +88 -0
- package/dist/heart/attachments/render.js +29 -0
- package/dist/heart/attachments/sources/bluebubbles.js +156 -0
- package/dist/heart/attachments/sources/cli-local-file.js +78 -0
- package/dist/heart/attachments/sources/index.js +16 -0
- package/dist/heart/attachments/store.js +103 -0
- package/dist/heart/attachments/types.js +93 -0
- package/dist/heart/auth/auth-flow.js +479 -0
- package/dist/heart/awaiting/await-alert.js +146 -0
- package/dist/heart/awaiting/await-expiry.js +108 -0
- package/dist/heart/awaiting/await-loader.js +91 -0
- package/dist/heart/awaiting/await-parser.js +141 -0
- package/dist/heart/awaiting/await-runtime-state.js +100 -0
- package/dist/heart/awaiting/await-scheduler.js +377 -0
- package/dist/heart/background-operations.js +281 -0
- package/dist/heart/bridges/manager.js +137 -17
- package/dist/heart/bridges/store.js +14 -2
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +135 -0
- package/dist/heart/config-registry.js +322 -0
- package/dist/heart/config.js +118 -119
- package/dist/heart/core.js +1123 -247
- package/dist/heart/cross-chat-delivery.js +3 -18
- package/dist/heart/daemon/agent-config-check.js +419 -0
- package/dist/heart/daemon/agent-discovery.js +102 -3
- package/dist/heart/daemon/agent-service.js +522 -0
- package/dist/heart/daemon/agentic-repair.js +547 -0
- package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
- package/dist/heart/daemon/boot-sync-probe.js +197 -0
- package/dist/heart/daemon/cadence.js +70 -0
- package/dist/heart/daemon/cli-defaults.js +780 -0
- package/dist/heart/daemon/cli-desk.js +322 -0
- package/dist/heart/daemon/cli-exec.js +7480 -0
- package/dist/heart/daemon/cli-help.js +505 -0
- package/dist/heart/daemon/cli-parse.js +1554 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +763 -0
- package/dist/heart/daemon/cli-types.js +8 -0
- package/dist/heart/daemon/connect-bay.js +323 -0
- package/dist/heart/daemon/daemon-cli.js +29 -1750
- package/dist/heart/daemon/daemon-entry.js +485 -2
- package/dist/heart/daemon/daemon-health.js +176 -0
- package/dist/heart/daemon/daemon-rollup.js +57 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +88 -13
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +932 -74
- package/dist/heart/daemon/dns-workflow.js +394 -0
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +873 -0
- package/dist/heart/daemon/health-monitor.js +122 -1
- package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
- package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
- package/dist/heart/daemon/http-health-probe.js +80 -0
- package/dist/heart/daemon/human-command-screens.js +234 -0
- package/dist/heart/daemon/human-readiness.js +114 -0
- package/dist/heart/daemon/inner-status.js +89 -0
- package/dist/heart/daemon/interactive-repair.js +394 -0
- package/dist/heart/daemon/launchd.js +37 -8
- package/dist/heart/daemon/log-tailer.js +79 -10
- package/dist/heart/daemon/logs-prune.js +110 -0
- package/dist/heart/daemon/mcp-canary.js +297 -0
- package/dist/heart/daemon/message-router.js +6 -2
- package/dist/heart/daemon/migrate-to-desk.js +848 -0
- package/dist/heart/daemon/os-cron-deps.js +135 -0
- package/dist/heart/daemon/os-cron.js +14 -12
- package/dist/heart/daemon/ouro-bot-entry.js +4 -2
- package/dist/heart/daemon/ouro-entry.js +3 -1
- package/dist/heart/daemon/plugin-cli.js +432 -0
- package/dist/heart/daemon/process-manager.js +510 -40
- package/dist/heart/daemon/provider-discovery.js +137 -0
- package/dist/heart/daemon/provider-ping-progress.js +83 -0
- package/dist/heart/daemon/pulse.js +475 -0
- package/dist/heart/daemon/readiness-repair.js +365 -0
- package/dist/heart/daemon/run-hooks.js +2 -0
- package/dist/heart/daemon/runtime-logging.js +35 -14
- package/dist/heart/daemon/runtime-metadata.js +2 -30
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +493 -38
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +1 -1
- package/dist/heart/daemon/socket-client.js +158 -11
- package/dist/heart/daemon/stale-bundle-prune.js +96 -0
- package/dist/heart/daemon/startup-tui.js +330 -0
- package/dist/heart/daemon/task-scheduler.js +117 -39
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +229 -17
- package/dist/heart/daemon/up-progress.js +366 -0
- package/dist/heart/daemon/vault-items.js +56 -0
- package/dist/heart/delegation.js +1 -4
- package/dist/heart/habits/habit-migration.js +189 -0
- package/dist/heart/habits/habit-parser.js +140 -0
- package/dist/heart/habits/habit-runtime-state.js +100 -0
- package/dist/heart/habits/habit-scheduler.js +372 -0
- package/dist/heart/{daemon → hatch}/hatch-flow.js +32 -56
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
- package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
- package/dist/heart/{daemon → hatch}/specialist-tools.js +37 -14
- package/dist/heart/identity.js +168 -57
- package/dist/heart/kept-notes.js +357 -0
- package/dist/heart/kicks.js +1 -1
- package/dist/heart/machine-identity.js +161 -0
- package/dist/heart/mail-import-discovery.js +353 -0
- package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
- package/dist/heart/mailbox/mailbox-http-response.js +7 -0
- package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
- package/dist/heart/mailbox/mailbox-http-static.js +103 -0
- package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
- package/dist/heart/mailbox/mailbox-http.js +99 -0
- package/dist/heart/mailbox/mailbox-read.js +31 -0
- package/dist/heart/mailbox/mailbox-types.js +27 -0
- package/dist/heart/mailbox/mailbox-view.js +197 -0
- package/dist/heart/mailbox/readers/agent-machine.js +418 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +319 -0
- package/dist/heart/mailbox/readers/mail.js +375 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +756 -0
- package/dist/heart/mailbox/readers/sessions.js +232 -0
- package/dist/heart/mailbox/readers/shared.js +111 -0
- package/dist/heart/mcp/mcp-server.js +692 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +19 -0
- package/dist/heart/orientation-frame.js +217 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +272 -0
- package/dist/heart/provider-credentials.js +425 -0
- package/dist/heart/provider-failover.js +311 -0
- package/dist/heart/provider-models.js +81 -0
- package/dist/heart/provider-ping.js +262 -0
- package/dist/heart/provider-readiness-cache.js +40 -0
- package/dist/heart/provider-visibility.js +188 -0
- package/dist/heart/providers/anthropic-token.js +131 -0
- package/dist/heart/providers/anthropic.js +139 -52
- package/dist/heart/providers/azure.js +23 -11
- package/dist/heart/providers/error-classification.js +127 -0
- package/dist/heart/providers/github-copilot.js +145 -0
- package/dist/heart/providers/minimax-vlm.js +189 -0
- package/dist/heart/providers/minimax.js +26 -8
- package/dist/heart/providers/openai-codex-token.js +349 -0
- package/dist/heart/providers/openai-codex.js +55 -40
- package/dist/heart/runtime-capability-check.js +170 -0
- package/dist/heart/runtime-credentials.js +367 -0
- package/dist/heart/runtime-cwd.js +87 -0
- package/dist/heart/sense-truth.js +13 -4
- package/dist/heart/session-activity.js +48 -24
- package/dist/heart/session-events.js +1163 -0
- package/dist/heart/session-playback-cli-main.js +5 -0
- package/dist/heart/session-playback-cli.js +36 -0
- package/dist/heart/session-playback.js +231 -0
- package/dist/heart/session-stats-cli-main.js +5 -0
- package/dist/heart/session-stats.js +182 -0
- package/dist/heart/session-transcript.js +133 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +44 -27
- package/dist/heart/structured-output.js +196 -0
- package/dist/heart/sync-classification.js +176 -0
- package/dist/heart/sync.js +449 -0
- package/dist/heart/target-resolution.js +9 -5
- package/dist/heart/tempo.js +93 -0
- package/dist/heart/temporal-view.js +41 -0
- package/dist/heart/timeouts.js +101 -0
- package/dist/heart/tool-activity-callbacks.js +59 -0
- package/dist/heart/tool-description.js +143 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +389 -0
- package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +6 -5
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +426 -0
- package/dist/heart/versioning/ouro-version-manager.js +409 -0
- package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
- package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
- package/dist/heart/versioning/update-hooks.js +154 -0
- package/dist/mailbox-ui/assets/index-9-AxCxuB.js +61 -0
- package/dist/mailbox-ui/assets/index-CWzt267f.css +1 -0
- package/dist/mailbox-ui/index.html +15 -0
- package/dist/mailroom/attention.js +167 -0
- package/dist/mailroom/autonomy.js +209 -0
- package/dist/mailroom/blob-store.js +715 -0
- package/dist/mailroom/body-cache.js +61 -0
- package/dist/mailroom/core.js +788 -0
- package/dist/mailroom/entry.js +160 -0
- package/dist/mailroom/file-store.js +568 -0
- package/dist/mailroom/mbox-import.js +393 -0
- package/dist/mailroom/migration.js +164 -0
- package/dist/mailroom/outbound.js +380 -0
- package/dist/mailroom/policy.js +263 -0
- package/dist/mailroom/reader.js +233 -0
- package/dist/mailroom/search-cache.js +334 -0
- package/dist/mailroom/search-relevance.js +319 -0
- package/dist/mailroom/smtp-ingress.js +176 -0
- package/dist/mailroom/source-state.js +176 -0
- package/dist/mailroom/thread.js +109 -0
- package/dist/mailroom/travel-extract.js +89 -0
- package/dist/mind/bundle-manifest.js +14 -1
- package/dist/mind/context.js +251 -101
- package/dist/mind/desk-section.js +310 -0
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +68 -76
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/friends/channel.js +39 -0
- package/dist/mind/friends/resolver.js +54 -2
- package/dist/mind/friends/store-file.js +48 -4
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/journal-index.js +162 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +6 -1
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1051 -138
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/nerves/cli-logging.js +7 -1
- package/dist/nerves/coverage/audit-rules.js +15 -6
- package/dist/nerves/coverage/audit.js +28 -2
- package/dist/nerves/coverage/cli.js +1 -1
- package/dist/nerves/coverage/contract.js +5 -5
- package/dist/nerves/coverage/file-completeness.js +139 -5
- package/dist/nerves/event-buffer.js +111 -0
- package/dist/nerves/index.js +224 -4
- package/dist/nerves/observation.js +20 -0
- package/dist/nerves/redact.js +79 -0
- package/dist/nerves/review/cli-main.js +5 -0
- package/dist/nerves/review/cli.js +156 -0
- package/dist/nerves/review/core.js +152 -0
- package/dist/nerves/runtime.js +5 -1
- package/dist/repertoire/ado-client.js +15 -56
- package/dist/repertoire/ado-semantic.js +16 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +1041 -0
- package/dist/repertoire/bundle-templates.js +72 -0
- package/dist/repertoire/bw-installer.js +180 -0
- package/dist/repertoire/coding/codex-jsonl.js +64 -0
- package/dist/repertoire/coding/context-pack.js +331 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +166 -10
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +219 -7
- package/dist/repertoire/commerce-errors.js +109 -0
- package/dist/repertoire/commerce-self-test.js +156 -0
- package/dist/repertoire/credential-access.js +178 -0
- package/dist/repertoire/desk/classifier.js +362 -0
- package/dist/repertoire/duffel-client.js +185 -0
- package/dist/repertoire/github-client.js +14 -55
- package/dist/repertoire/graph-client.js +11 -52
- package/dist/repertoire/guardrails.js +136 -25
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +403 -0
- package/dist/repertoire/mcp-tools.js +83 -0
- package/dist/repertoire/plugin-mcp.js +175 -0
- package/dist/repertoire/plugins.js +253 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +48 -4
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-awaiting.js +372 -0
- package/dist/repertoire/tools-base.js +59 -1082
- package/dist/repertoire/tools-bluebubbles.js +2 -0
- package/dist/repertoire/tools-bridge.js +144 -0
- package/dist/repertoire/tools-bundle.js +993 -0
- package/dist/repertoire/tools-config.js +186 -0
- package/dist/repertoire/tools-continuity.js +252 -0
- package/dist/repertoire/tools-credential.js +383 -0
- package/dist/repertoire/tools-evolution.js +527 -0
- package/dist/repertoire/tools-files.js +344 -0
- package/dist/repertoire/tools-flight.js +227 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +3 -8
- package/dist/repertoire/tools-mail.js +1975 -0
- package/dist/repertoire/tools-notes.js +438 -0
- package/dist/repertoire/tools-obligations.js +143 -0
- package/dist/repertoire/tools-orientation.js +31 -0
- package/dist/repertoire/tools-record.js +464 -0
- package/dist/repertoire/tools-runtime.js +150 -0
- package/dist/repertoire/tools-session.js +766 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +182 -0
- package/dist/repertoire/tools-surface.js +344 -0
- package/dist/repertoire/tools-teams.js +12 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +982 -0
- package/dist/repertoire/tools-user-profile.js +146 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools-voice.js +145 -0
- package/dist/repertoire/tools.js +193 -77
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +131 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +594 -0
- package/dist/scripts/claude-code-hook.js +41 -0
- package/dist/scripts/claude-code-stop-hook.js +47 -0
- package/dist/senses/attention-queue.js +186 -0
- package/dist/senses/await-turn-message.js +58 -0
- package/dist/senses/bluebubbles/active-turns.js +216 -0
- package/dist/senses/bluebubbles/attachment-cache.js +53 -0
- package/dist/senses/bluebubbles/attachment-download.js +137 -0
- package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
- package/dist/senses/bluebubbles/entry.js +77 -0
- package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
- package/dist/senses/bluebubbles/index.js +2737 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -71
- package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
- package/dist/senses/bluebubbles/processed-log.js +133 -0
- package/dist/senses/bluebubbles/replay.js +137 -0
- package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
- package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
- package/dist/senses/bluebubbles-meta-guard.js +40 -0
- package/dist/senses/cli/bracketed-paste.js +82 -0
- package/dist/senses/cli/image-paste.js +287 -0
- package/dist/senses/cli/image-ref-navigation.js +75 -0
- package/dist/senses/cli/ink-app.js +156 -0
- package/dist/senses/cli/inline-diff.js +64 -0
- package/dist/senses/cli/input-keys.js +174 -0
- package/dist/senses/cli/kill-ring.js +86 -0
- package/dist/senses/cli/message-list.js +51 -0
- package/dist/senses/cli/ouro-tui.js +607 -0
- package/dist/senses/cli/spinner-imperative.js +135 -0
- package/dist/senses/cli/spinner.js +101 -0
- package/dist/senses/cli/status-line.js +60 -0
- package/dist/senses/cli/streaming-markdown.js +526 -0
- package/dist/senses/cli/tool-display.js +85 -0
- package/dist/senses/cli/tool-render.js +85 -0
- package/dist/senses/cli/tui-store.js +240 -0
- package/dist/senses/cli/virtual-list.js +35 -0
- package/dist/senses/cli-entry.js +60 -8
- package/dist/senses/cli-layout.js +100 -0
- package/dist/senses/cli.js +517 -204
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +254 -22
- package/dist/senses/inner-dialog.js +505 -40
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +711 -181
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +393 -0
- package/dist/senses/surface-tool.js +108 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +390 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/senses/voice/audio-playback.js +237 -0
- package/dist/senses/voice/audio-routing.js +119 -0
- package/dist/senses/voice/elevenlabs.js +202 -0
- package/dist/senses/voice/floor-control.js +431 -0
- package/dist/senses/voice/floor-controller.js +115 -0
- package/dist/senses/voice/golden-path.js +116 -0
- package/dist/senses/voice/index.js +29 -0
- package/dist/senses/voice/meeting.js +113 -0
- package/dist/senses/voice/outbound.js +190 -0
- package/dist/senses/voice/phone.js +33 -0
- package/dist/senses/voice/playback.js +139 -0
- package/dist/senses/voice/realtime-eval.js +496 -0
- package/dist/senses/voice/realtime-trace.js +531 -0
- package/dist/senses/voice/transcript.js +70 -0
- package/dist/senses/voice/turn.js +191 -0
- package/dist/senses/voice/twilio-phone-runtime.js +807 -0
- package/dist/senses/voice/twilio-phone.js +5079 -0
- package/dist/senses/voice/types.js +2 -0
- package/dist/senses/voice/whisper.js +161 -0
- package/dist/senses/voice-entry.js +81 -0
- package/dist/senses/voice-realtime-eval-command.js +99 -0
- package/dist/senses/voice-realtime-eval-entry.js +21 -0
- package/dist/senses/voice-twilio-entry.js +87 -0
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +265 -0
- package/dist/util/frontmatter.js +53 -0
- package/package.json +53 -10
- package/skills/agent-commerce.md +106 -0
- package/skills/browser-navigation.md +117 -0
- package/skills/commerce-setup-guide.md +116 -0
- package/skills/commerce-setup.md +84 -0
- package/skills/configure-dev-tools.md +99 -0
- package/skills/travel-planning.md +138 -0
- package/dist/heart/daemon/auth-flow.js +0 -351
- package/dist/heart/daemon/ouro-path-installer.js +0 -178
- package/dist/heart/daemon/update-hooks.js +0 -138
- package/dist/heart/safe-workspace.js +0 -228
- package/dist/heart/session-recall.js +0 -116
- package/dist/mind/associative-recall.js +0 -209
- package/dist/repertoire/tasks/board.js +0 -134
- package/dist/repertoire/tasks/index.js +0 -224
- package/dist/repertoire/tasks/lifecycle.js +0 -80
- package/dist/repertoire/tasks/middleware.js +0 -65
- package/dist/repertoire/tasks/parser.js +0 -173
- package/dist/repertoire/tasks/scanner.js +0 -132
- package/dist/repertoire/tasks/transitions.js +0 -144
- package/dist/senses/bluebubbles-entry.js +0 -13
- package/dist/senses/bluebubbles.js +0 -1177
- package/dist/senses/debug-activity.js +0 -148
- package/subagents/README.md +0 -7
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
- /package/dist/{repertoire/tasks/types.js → heart/attachments/sources/adapter.js} +0 -0
- /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
- /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
- /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
- /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
package/dist/repertoire/tools.js
CHANGED
|
@@ -1,18 +1,24 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.surfaceToolDef = exports.speakTool = 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");
|
|
14
|
+
const tools_bundle_1 = require("./tools-bundle");
|
|
13
15
|
const runtime_1 = require("../nerves/runtime");
|
|
14
16
|
const guardrails_1 = require("./guardrails");
|
|
15
17
|
const identity_1 = require("../heart/identity");
|
|
18
|
+
const tools_surface_1 = require("./tools-surface");
|
|
19
|
+
const mcp_tools_1 = require("./mcp-tools");
|
|
20
|
+
const tools_voice_1 = require("./tools-voice");
|
|
21
|
+
const shell_sessions_1 = require("./shell-sessions");
|
|
16
22
|
function safeGetAgentRoot() {
|
|
17
23
|
try {
|
|
18
24
|
return (0, identity_1.getAgentRoot)();
|
|
@@ -24,9 +30,23 @@ function safeGetAgentRoot() {
|
|
|
24
30
|
// Re-export types and constants used by the rest of the codebase
|
|
25
31
|
var tools_base_2 = require("./tools-base");
|
|
26
32
|
Object.defineProperty(exports, "tools", { enumerable: true, get: function () { return tools_base_2.tools; } });
|
|
27
|
-
Object.defineProperty(exports, "
|
|
33
|
+
Object.defineProperty(exports, "settleTool", { enumerable: true, get: function () { return tools_base_2.settleTool; } });
|
|
34
|
+
Object.defineProperty(exports, "observeTool", { enumerable: true, get: function () { return tools_base_2.observeTool; } });
|
|
35
|
+
Object.defineProperty(exports, "ponderTool", { enumerable: true, get: function () { return tools_base_2.ponderTool; } });
|
|
36
|
+
Object.defineProperty(exports, "restTool", { enumerable: true, get: function () { return tools_base_2.restTool; } });
|
|
37
|
+
Object.defineProperty(exports, "speakTool", { enumerable: true, get: function () { return tools_base_2.speakTool; } });
|
|
38
|
+
// Re-export surface tool schema for consumers (e.g. heart/core.ts)
|
|
39
|
+
var tools_surface_2 = require("./tools-surface");
|
|
40
|
+
Object.defineProperty(exports, "surfaceToolDef", { enumerable: true, get: function () { return tools_surface_2.surfaceToolDef; } });
|
|
28
41
|
// All tool definitions in a single registry
|
|
29
|
-
const allDefinitions = [...tools_base_1.baseToolDefinitions, ...tools_bluebubbles_1.bluebubblesToolDefinitions, ...tools_teams_1.teamsToolDefinitions, ...ado_semantic_1.adoSemanticToolDefinitions, ...tools_github_1.githubToolDefinitions];
|
|
42
|
+
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_voice_1.voiceToolDefinitions, tools_surface_1.surfaceToolDefinition];
|
|
43
|
+
// MCP tool definitions — populated each time getToolsForChannel() is called with an mcpManager.
|
|
44
|
+
// Kept separate from allDefinitions so execTool can find them.
|
|
45
|
+
let mcpDefinitions = [];
|
|
46
|
+
/** Exported for testing — reset the MCP definitions cache. */
|
|
47
|
+
function resetMcpDefinitions() {
|
|
48
|
+
mcpDefinitions = [];
|
|
49
|
+
}
|
|
30
50
|
function baseToolsForCapabilities() {
|
|
31
51
|
// Use baseToolDefinitions at call time so dynamically-added tools are included
|
|
32
52
|
return tools_base_1.baseToolDefinitions.map((d) => d.tool);
|
|
@@ -57,14 +77,17 @@ function filterByCapability(toolList, providerCapabilities) {
|
|
|
57
77
|
// Teams/integration tools are included only if their integration is in availableIntegrations.
|
|
58
78
|
// When toolPreferences is provided, matching preferences are appended to tool descriptions.
|
|
59
79
|
// When providerCapabilities is provided, tools with requiredCapability are filtered.
|
|
60
|
-
function getToolsForChannel(capabilities, toolPreferences, _context, providerCapabilities) {
|
|
80
|
+
function getToolsForChannel(capabilities, toolPreferences, _context, providerCapabilities, mcpManager, _chatModel) {
|
|
61
81
|
const baseTools = baseToolsForCapabilities();
|
|
62
82
|
const bluebubblesTools = capabilities?.channel === "bluebubbles"
|
|
63
83
|
? tools_bluebubbles_1.bluebubblesToolDefinitions.map((d) => d.tool)
|
|
64
84
|
: [];
|
|
85
|
+
const voiceTools = capabilities?.channel === "voice"
|
|
86
|
+
? tools_voice_1.voiceToolDefinitions.map((d) => d.tool)
|
|
87
|
+
: [];
|
|
65
88
|
let result;
|
|
66
89
|
if (!capabilities || capabilities.availableIntegrations.length === 0) {
|
|
67
|
-
result = [...baseTools, ...bluebubblesTools];
|
|
90
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools];
|
|
68
91
|
}
|
|
69
92
|
else {
|
|
70
93
|
const available = new Set(capabilities.availableIntegrations);
|
|
@@ -72,7 +95,7 @@ function getToolsForChannel(capabilities, toolPreferences, _context, providerCap
|
|
|
72
95
|
// Include tools whose integration is available, plus channel tools with no integration gate (e.g. teams_send_message)
|
|
73
96
|
const integrationDefs = channelDefs.filter((d) => d.integration ? available.has(d.integration) : capabilities.channel === "teams");
|
|
74
97
|
if (!toolPreferences || Object.keys(toolPreferences).length === 0) {
|
|
75
|
-
result = [...baseTools, ...bluebubblesTools, ...integrationDefs.map((d) => d.tool)];
|
|
98
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools, ...integrationDefs.map((d) => d.tool)];
|
|
76
99
|
}
|
|
77
100
|
else {
|
|
78
101
|
// Build a map of integration -> preference text for fast lookup
|
|
@@ -86,26 +109,118 @@ function getToolsForChannel(capabilities, toolPreferences, _context, providerCap
|
|
|
86
109
|
const pref = prefMap.get(d.integration);
|
|
87
110
|
return pref ? applyPreference(d.tool, pref) : d.tool;
|
|
88
111
|
});
|
|
89
|
-
result = [...baseTools, ...bluebubblesTools, ...enrichedIntegrationTools];
|
|
112
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools, ...enrichedIntegrationTools];
|
|
90
113
|
}
|
|
91
114
|
}
|
|
115
|
+
// Append first-class MCP tools when mcpManager is provided
|
|
116
|
+
if (mcpManager) {
|
|
117
|
+
mcpDefinitions = (0, mcp_tools_1.mcpToolsAsDefinitions)(mcpManager);
|
|
118
|
+
const mcpSchemas = mcpDefinitions.map((d) => d.tool);
|
|
119
|
+
result = [...result, ...mcpSchemas];
|
|
120
|
+
}
|
|
92
121
|
return filterByCapability(result, providerCapabilities);
|
|
93
122
|
}
|
|
94
|
-
//
|
|
95
|
-
|
|
96
|
-
function
|
|
97
|
-
|
|
98
|
-
|
|
123
|
+
// Look up a tool definition from the combined registry (native + MCP).
|
|
124
|
+
function findDefinition(toolName) {
|
|
125
|
+
return allDefinitions.find((d) => d.tool.function.name === toolName)
|
|
126
|
+
?? mcpDefinitions.find((d) => d.tool.function.name === toolName);
|
|
127
|
+
}
|
|
128
|
+
function normalizeGuardArgs(_name, args) {
|
|
129
|
+
return args;
|
|
130
|
+
}
|
|
131
|
+
const READ_ONLY_OURO_SHELL_COMMANDS = new Set([
|
|
132
|
+
"help",
|
|
133
|
+
"-h",
|
|
134
|
+
"--help",
|
|
135
|
+
"-v",
|
|
136
|
+
"--version",
|
|
137
|
+
"status",
|
|
138
|
+
"whoami",
|
|
139
|
+
"versions",
|
|
140
|
+
"changelog",
|
|
141
|
+
"mailbox",
|
|
142
|
+
"inner",
|
|
143
|
+
"thoughts",
|
|
144
|
+
"check",
|
|
145
|
+
"session list",
|
|
146
|
+
"mcp list",
|
|
147
|
+
"config models",
|
|
148
|
+
"auth verify",
|
|
149
|
+
"vault status",
|
|
150
|
+
"vault config status",
|
|
151
|
+
"vault item status",
|
|
152
|
+
"vault item list",
|
|
153
|
+
]);
|
|
154
|
+
function shellTokens(command) {
|
|
155
|
+
return command.trim().split(/\s+/).filter(Boolean);
|
|
156
|
+
}
|
|
157
|
+
function ouroShellRiskReason(command) {
|
|
158
|
+
const tokens = shellTokens(command);
|
|
159
|
+
if (tokens[0] !== "ouro")
|
|
160
|
+
return null;
|
|
161
|
+
const first = tokens[1] ?? "";
|
|
162
|
+
const second = tokens[2] ?? "";
|
|
163
|
+
const third = tokens[3] ?? "";
|
|
164
|
+
const twoWord = second ? `${first} ${second}` : first;
|
|
165
|
+
const threeWord = third ? `${twoWord} ${third}` : twoWord;
|
|
166
|
+
if (READ_ONLY_OURO_SHELL_COMMANDS.has(threeWord)
|
|
167
|
+
|| READ_ONLY_OURO_SHELL_COMMANDS.has(twoWord)
|
|
168
|
+
|| READ_ONLY_OURO_SHELL_COMMANDS.has(first)) {
|
|
169
|
+
return null;
|
|
170
|
+
}
|
|
171
|
+
const hint = first === "restart_runtime"
|
|
172
|
+
? " Hint: use the restart_runtime tool instead of shell."
|
|
173
|
+
: "";
|
|
174
|
+
return `ouro CLI command may mutate runtime/config state or be unavailable from shell.${hint}`;
|
|
175
|
+
}
|
|
176
|
+
function shellRiskProfile(args) {
|
|
177
|
+
const command = String(args.command);
|
|
178
|
+
const destructive = (0, shell_sessions_1.detectDestructivePatterns)(command);
|
|
179
|
+
if (destructive.length > 0) {
|
|
180
|
+
return { mutates: "external_side_effect", risk: "high", reason: `destructive shell pattern: ${destructive.join(", ")}` };
|
|
181
|
+
}
|
|
182
|
+
const ouroRiskReason = ouroShellRiskReason(command);
|
|
183
|
+
if (ouroRiskReason) {
|
|
184
|
+
return { mutates: "external_side_effect", risk: "high", reason: ouroRiskReason };
|
|
185
|
+
}
|
|
186
|
+
if (/(^|\s)(rm|mv|cp|touch|mkdir|rmdir)\b/.test(command)
|
|
187
|
+
|| /(^|\s)(npm|pnpm|yarn)\s+(install|add|remove|update|upgrade)\b/.test(command)
|
|
188
|
+
|| /(^|\s)git\s+(add|apply|checkout|clean|commit|merge|pull|push|rebase|reset|restore|switch)\b/.test(command)
|
|
189
|
+
|| /(^|\s)(sed\s+-i|perl\s+-pi)\b/.test(command)
|
|
190
|
+
|| /(^|\s)(tee|truncate)\b/.test(command)
|
|
191
|
+
|| /(^|[^<])>>?\s*\S+/.test(command)) {
|
|
192
|
+
return { mutates: "external_side_effect", risk: "high", reason: "shell command appears to mutate files, packages, git state, or external state" };
|
|
193
|
+
}
|
|
194
|
+
return { mutates: "none", risk: "low" };
|
|
195
|
+
}
|
|
196
|
+
function riskProfileForTool(def, name, args) {
|
|
197
|
+
if (name === "shell")
|
|
198
|
+
return shellRiskProfile(args);
|
|
199
|
+
if (typeof def.riskProfile === "function")
|
|
200
|
+
return def.riskProfile(args);
|
|
201
|
+
return def.riskProfile ?? { mutates: "none", risk: "low" };
|
|
202
|
+
}
|
|
203
|
+
function orientationHoldMessage(name, profile, reason) {
|
|
204
|
+
return `orientation hold: ${reason} Available: orientation_get plus read-only inspection tools like trip_status, query_session, read_config, read_file, grep, and search_notes. Resolve the referent/correction, then retry ${name} if the action is still correct. Blocked ${mutationKindsFor(profile).join(", ")}. ${profile.reason}.`;
|
|
205
|
+
}
|
|
206
|
+
function mutationKindsFor(profile) {
|
|
207
|
+
const mutates = profile.mutates;
|
|
208
|
+
return typeof mutates === "string" ? [mutates] : [...mutates];
|
|
209
|
+
}
|
|
210
|
+
function orientationPolicyBlocks(profile, blockedMutationKinds) {
|
|
211
|
+
if (profile.risk !== "high")
|
|
212
|
+
return false;
|
|
213
|
+
return mutationKindsFor(profile).some((kind) => blockedMutationKinds.includes(kind));
|
|
99
214
|
}
|
|
100
215
|
async function execTool(name, args, ctx) {
|
|
101
216
|
(0, runtime_1.emitNervesEvent)({
|
|
102
217
|
event: "tool.start",
|
|
103
218
|
component: "tools",
|
|
104
219
|
message: "tool execution started",
|
|
105
|
-
meta: { name },
|
|
220
|
+
meta: { name, ...(name === "shell" && args.command ? { command: args.command } : {}) },
|
|
106
221
|
});
|
|
107
|
-
// Look up from combined registry
|
|
108
|
-
const def =
|
|
222
|
+
// Look up from combined registry (native + MCP)
|
|
223
|
+
const def = findDefinition(name);
|
|
109
224
|
if (!def) {
|
|
110
225
|
(0, runtime_1.emitNervesEvent)({
|
|
111
226
|
level: "error",
|
|
@@ -116,13 +231,32 @@ async function execTool(name, args, ctx) {
|
|
|
116
231
|
});
|
|
117
232
|
return `unknown: ${name}`;
|
|
118
233
|
}
|
|
234
|
+
const riskProfile = riskProfileForTool(def, name, args);
|
|
235
|
+
const orientationPolicy = ctx?.orientationFrame?.actionPolicy;
|
|
236
|
+
if (orientationPolicy?.mode === "correction_hold"
|
|
237
|
+
&& orientationPolicyBlocks(riskProfile, orientationPolicy.blockedMutationKinds)) {
|
|
238
|
+
const reason = orientationPolicy.reason;
|
|
239
|
+
const message = orientationHoldMessage(name, riskProfile, reason);
|
|
240
|
+
(0, runtime_1.emitNervesEvent)({
|
|
241
|
+
level: "warn",
|
|
242
|
+
event: "tool.orientation_hold_block",
|
|
243
|
+
component: "tools",
|
|
244
|
+
message: "orientation hold blocked high-risk tool execution",
|
|
245
|
+
meta: { name, mutates: mutationKindsFor(riskProfile), reason },
|
|
246
|
+
});
|
|
247
|
+
return message;
|
|
248
|
+
}
|
|
119
249
|
// Guardrail check: structural + trust-level
|
|
250
|
+
const mcpDef = mcpDefinitions.find((d) => d.tool.function.name === name);
|
|
120
251
|
const guardContext = {
|
|
121
252
|
readPaths: tools_base_1.editFileReadTracker,
|
|
122
253
|
trustLevel: ctx?.context?.friend?.trustLevel,
|
|
123
254
|
agentRoot: safeGetAgentRoot(),
|
|
255
|
+
...(mcpDef?.mcpServer ? { mcpServerName: mcpDef.mcpServer } : {}),
|
|
256
|
+
...(ctx?.context?.isGroupChat !== undefined ? { isGroupChat: (ctx?.context).isGroupChat } : {}),
|
|
124
257
|
};
|
|
125
|
-
const
|
|
258
|
+
const guardArgs = normalizeGuardArgs(name, args);
|
|
259
|
+
const guardResult = (0, guardrails_1.guardInvocation)(name, guardArgs, guardContext);
|
|
126
260
|
if (!guardResult.allowed) {
|
|
127
261
|
(0, runtime_1.emitNervesEvent)({
|
|
128
262
|
level: "warn",
|
|
@@ -175,65 +309,47 @@ function summarizeUnknownArgs(args) {
|
|
|
175
309
|
return summarizeKeyValues(args, keys);
|
|
176
310
|
}
|
|
177
311
|
function summarizeArgs(name, args) {
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
// Check github tools
|
|
183
|
-
const githubSummary = (0, tools_github_1.summarizeGithubArgs)(name, args);
|
|
184
|
-
if (githubSummary !== undefined)
|
|
185
|
-
return githubSummary;
|
|
186
|
-
// Base tools
|
|
187
|
-
if (name === "read_file" || name === "write_file")
|
|
188
|
-
return summarizeKeyValues(args, ["path"]);
|
|
189
|
-
if (name === "edit_file")
|
|
190
|
-
return summarizeKeyValues(args, ["path"]);
|
|
191
|
-
if (name === "glob")
|
|
192
|
-
return summarizeKeyValues(args, ["pattern", "cwd"]);
|
|
193
|
-
if (name === "grep")
|
|
194
|
-
return summarizeKeyValues(args, ["pattern", "path", "include"]);
|
|
195
|
-
if (name === "shell")
|
|
196
|
-
return summarizeKeyValues(args, ["command"]);
|
|
197
|
-
if (name === "load_skill")
|
|
198
|
-
return summarizeKeyValues(args, ["name"]);
|
|
199
|
-
if (name === "coding_spawn")
|
|
200
|
-
return summarizeKeyValues(args, ["runner", "workdir", "taskRef"]);
|
|
201
|
-
if (name === "coding_status")
|
|
202
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
203
|
-
if (name === "coding_tail")
|
|
204
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
205
|
-
if (name === "coding_send_input")
|
|
206
|
-
return summarizeKeyValues(args, ["sessionId", "input"]);
|
|
207
|
-
if (name === "coding_kill")
|
|
208
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
209
|
-
if (name === "bluebubbles_set_reply_target")
|
|
210
|
-
return summarizeKeyValues(args, ["target", "threadOriginatorGuid"]);
|
|
211
|
-
if (name === "set_reasoning_effort")
|
|
212
|
-
return summarizeKeyValues(args, ["level"]);
|
|
213
|
-
if (name === "claude")
|
|
214
|
-
return summarizeKeyValues(args, ["prompt"]);
|
|
215
|
-
if (name === "web_search")
|
|
216
|
-
return summarizeKeyValues(args, ["query"]);
|
|
217
|
-
if (name === "memory_search")
|
|
218
|
-
return summarizeKeyValues(args, ["query"]);
|
|
219
|
-
if (name === "memory_save")
|
|
220
|
-
return summarizeKeyValues(args, ["text", "about"]);
|
|
221
|
-
if (name === "get_friend_note")
|
|
222
|
-
return summarizeKeyValues(args, ["friendId"]);
|
|
223
|
-
if (name === "save_friend_note") {
|
|
224
|
-
return summarizeKeyValues(args, ["type", "key", "content"]);
|
|
225
|
-
}
|
|
226
|
-
if (name === "bridge_manage")
|
|
227
|
-
return summarizeKeyValues(args, ["action", "bridgeId", "objective", "friendId", "channel", "key"]);
|
|
228
|
-
if (name === "ado_backlog_list")
|
|
229
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
230
|
-
if (name === "ado_batch_update")
|
|
231
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
232
|
-
if (name === "ado_create_epic" || name === "ado_create_issue")
|
|
233
|
-
return summarizeKeyValues(args, ["organization", "project", "title"]);
|
|
234
|
-
if (name === "ado_move_items")
|
|
235
|
-
return summarizeKeyValues(args, ["organization", "project", "workItemIds"]);
|
|
236
|
-
if (name === "ado_restructure_backlog")
|
|
237
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
312
|
+
const def = findDefinition(name);
|
|
313
|
+
if (def && def.summaryKeys !== undefined) {
|
|
314
|
+
return summarizeKeyValues(args, def.summaryKeys);
|
|
315
|
+
}
|
|
238
316
|
return summarizeUnknownArgs(args);
|
|
239
317
|
}
|
|
318
|
+
/**
|
|
319
|
+
* Build an enriched tool result summary for display on remote channels.
|
|
320
|
+
* For recognized tools, includes result-derived info (diff stats, exit codes, etc.).
|
|
321
|
+
* Falls back to arg-based summary for unrecognized tools.
|
|
322
|
+
*/
|
|
323
|
+
function buildToolResultSummary(name, args, _result, success) {
|
|
324
|
+
/* v8 ignore start -- branches: ?? fallbacks and ternaries in tool summary formatting @preserve */
|
|
325
|
+
switch (name) {
|
|
326
|
+
case "edit_file": {
|
|
327
|
+
if (!success)
|
|
328
|
+
return summarizeArgs(name, args);
|
|
329
|
+
const addedLines = (args.new_string ?? "").split("\n").length;
|
|
330
|
+
const removedLines = (args.old_string ?? "").split("\n").length;
|
|
331
|
+
return `+${addedLines} -${removedLines} lines in ${args.path ?? "unknown"}`;
|
|
332
|
+
}
|
|
333
|
+
case "shell": {
|
|
334
|
+
const cmd = args.command ?? "?";
|
|
335
|
+
const exitCode = success ? 0 : 1;
|
|
336
|
+
return `$ ${cmd} (exit ${exitCode})`;
|
|
337
|
+
}
|
|
338
|
+
case "read_file":
|
|
339
|
+
return `path=${args.path ?? "unknown"}`;
|
|
340
|
+
case "write_file":
|
|
341
|
+
return `path=${args.path ?? "unknown"}`;
|
|
342
|
+
case "glob":
|
|
343
|
+
return `pattern=${args.pattern ?? "?"} ${args.cwd ? `cwd=${args.cwd}` : ""}`.trim();
|
|
344
|
+
case "grep":
|
|
345
|
+
return `pattern=${args.pattern ?? "?"} ${args.path ? `path=${args.path}` : ""}`.trim();
|
|
346
|
+
case "coding_spawn": {
|
|
347
|
+
const taskRef = args.taskRef ?? "unknown";
|
|
348
|
+
const status = success ? "spawned" : "failed";
|
|
349
|
+
return `${taskRef} -> ${status}`;
|
|
350
|
+
}
|
|
351
|
+
default:
|
|
352
|
+
return summarizeArgs(name, args);
|
|
353
|
+
}
|
|
354
|
+
/* v8 ignore stop */
|
|
355
|
+
}
|