@ouro.bot/cli 0.1.0-alpha.62 → 0.1.0-alpha.637
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 +4087 -13
- 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 +114 -119
- package/dist/heart/core.js +1028 -248
- 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 +776 -0
- package/dist/heart/daemon/cli-desk.js +322 -0
- package/dist/heart/daemon/cli-exec.js +7468 -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 -1700
- 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 +906 -71
- 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/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 +501 -35
- 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 +11 -3
- 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 +22 -9
- 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 +301 -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.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 +295 -0
- package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
- package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
- package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
- 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 +1075 -146
- 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 +1040 -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 +385 -0
- 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 +215 -103
- 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 +666 -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 +388 -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 +48 -8
- 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/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,45 +1,55 @@
|
|
|
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");
|
|
13
|
-
const
|
|
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
|
+
const tools_voice_1 = require("./tools-voice");
|
|
21
|
+
const shell_sessions_1 = require("./shell-sessions");
|
|
22
|
+
function safeGetAgentRoot() {
|
|
23
|
+
try {
|
|
24
|
+
return (0, identity_1.getAgentRoot)();
|
|
25
|
+
}
|
|
26
|
+
catch {
|
|
27
|
+
return undefined;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
16
30
|
// Re-export types and constants used by the rest of the codebase
|
|
17
31
|
var tools_base_2 = require("./tools-base");
|
|
18
32
|
Object.defineProperty(exports, "tools", { enumerable: true, get: function () { return tools_base_2.tools; } });
|
|
19
|
-
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; } });
|
|
20
41
|
// 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
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
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 = [];
|
|
28
49
|
}
|
|
29
|
-
function
|
|
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) {
|
|
50
|
+
function baseToolsForCapabilities() {
|
|
38
51
|
// Use baseToolDefinitions at call time so dynamically-added tools are included
|
|
39
|
-
|
|
40
|
-
if (!shouldBlockLocalTools(capabilities, context))
|
|
41
|
-
return currentTools;
|
|
42
|
-
return currentTools.filter((tool) => !exports.REMOTE_BLOCKED_LOCAL_TOOLS.has(tool.function.name));
|
|
52
|
+
return tools_base_1.baseToolDefinitions.map((d) => d.tool);
|
|
43
53
|
}
|
|
44
54
|
// Apply a single tool preference to a tool schema, returning a new object.
|
|
45
55
|
function applyPreference(tool, pref) {
|
|
@@ -67,14 +77,17 @@ function filterByCapability(toolList, providerCapabilities) {
|
|
|
67
77
|
// Teams/integration tools are included only if their integration is in availableIntegrations.
|
|
68
78
|
// When toolPreferences is provided, matching preferences are appended to tool descriptions.
|
|
69
79
|
// When providerCapabilities is provided, tools with requiredCapability are filtered.
|
|
70
|
-
function getToolsForChannel(capabilities, toolPreferences,
|
|
71
|
-
const baseTools = baseToolsForCapabilities(
|
|
80
|
+
function getToolsForChannel(capabilities, toolPreferences, _context, providerCapabilities, mcpManager, _chatModel) {
|
|
81
|
+
const baseTools = baseToolsForCapabilities();
|
|
72
82
|
const bluebubblesTools = capabilities?.channel === "bluebubbles"
|
|
73
83
|
? tools_bluebubbles_1.bluebubblesToolDefinitions.map((d) => d.tool)
|
|
74
84
|
: [];
|
|
85
|
+
const voiceTools = capabilities?.channel === "voice"
|
|
86
|
+
? tools_voice_1.voiceToolDefinitions.map((d) => d.tool)
|
|
87
|
+
: [];
|
|
75
88
|
let result;
|
|
76
89
|
if (!capabilities || capabilities.availableIntegrations.length === 0) {
|
|
77
|
-
result = [...baseTools, ...bluebubblesTools];
|
|
90
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools];
|
|
78
91
|
}
|
|
79
92
|
else {
|
|
80
93
|
const available = new Set(capabilities.availableIntegrations);
|
|
@@ -82,7 +95,7 @@ function getToolsForChannel(capabilities, toolPreferences, context, providerCapa
|
|
|
82
95
|
// Include tools whose integration is available, plus channel tools with no integration gate (e.g. teams_send_message)
|
|
83
96
|
const integrationDefs = channelDefs.filter((d) => d.integration ? available.has(d.integration) : capabilities.channel === "teams");
|
|
84
97
|
if (!toolPreferences || Object.keys(toolPreferences).length === 0) {
|
|
85
|
-
result = [...baseTools, ...bluebubblesTools, ...integrationDefs.map((d) => d.tool)];
|
|
98
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools, ...integrationDefs.map((d) => d.tool)];
|
|
86
99
|
}
|
|
87
100
|
else {
|
|
88
101
|
// Build a map of integration -> preference text for fast lookup
|
|
@@ -96,26 +109,118 @@ function getToolsForChannel(capabilities, toolPreferences, context, providerCapa
|
|
|
96
109
|
const pref = prefMap.get(d.integration);
|
|
97
110
|
return pref ? applyPreference(d.tool, pref) : d.tool;
|
|
98
111
|
});
|
|
99
|
-
result = [...baseTools, ...bluebubblesTools, ...enrichedIntegrationTools];
|
|
112
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools, ...enrichedIntegrationTools];
|
|
100
113
|
}
|
|
101
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
|
+
}
|
|
102
121
|
return filterByCapability(result, providerCapabilities);
|
|
103
122
|
}
|
|
104
|
-
//
|
|
105
|
-
|
|
106
|
-
function
|
|
107
|
-
|
|
108
|
-
|
|
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));
|
|
109
214
|
}
|
|
110
215
|
async function execTool(name, args, ctx) {
|
|
111
216
|
(0, runtime_1.emitNervesEvent)({
|
|
112
217
|
event: "tool.start",
|
|
113
218
|
component: "tools",
|
|
114
219
|
message: "tool execution started",
|
|
115
|
-
meta: { name },
|
|
220
|
+
meta: { name, ...(name === "shell" && args.command ? { command: args.command } : {}) },
|
|
116
221
|
});
|
|
117
|
-
// Look up from combined registry
|
|
118
|
-
const def =
|
|
222
|
+
// Look up from combined registry (native + MCP)
|
|
223
|
+
const def = findDefinition(name);
|
|
119
224
|
if (!def) {
|
|
120
225
|
(0, runtime_1.emitNervesEvent)({
|
|
121
226
|
level: "error",
|
|
@@ -126,17 +231,42 @@ async function execTool(name, args, ctx) {
|
|
|
126
231
|
});
|
|
127
232
|
return `unknown: ${name}`;
|
|
128
233
|
}
|
|
129
|
-
|
|
130
|
-
|
|
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);
|
|
131
240
|
(0, runtime_1.emitNervesEvent)({
|
|
132
241
|
level: "warn",
|
|
133
|
-
event: "tool.
|
|
242
|
+
event: "tool.orientation_hold_block",
|
|
134
243
|
component: "tools",
|
|
135
|
-
message: "blocked
|
|
136
|
-
meta: { name,
|
|
244
|
+
message: "orientation hold blocked high-risk tool execution",
|
|
245
|
+
meta: { name, mutates: mutationKindsFor(riskProfile), reason },
|
|
137
246
|
});
|
|
138
247
|
return message;
|
|
139
248
|
}
|
|
249
|
+
// Guardrail check: structural + trust-level
|
|
250
|
+
const mcpDef = mcpDefinitions.find((d) => d.tool.function.name === name);
|
|
251
|
+
const guardContext = {
|
|
252
|
+
readPaths: tools_base_1.editFileReadTracker,
|
|
253
|
+
trustLevel: ctx?.context?.friend?.trustLevel,
|
|
254
|
+
agentRoot: safeGetAgentRoot(),
|
|
255
|
+
...(mcpDef?.mcpServer ? { mcpServerName: mcpDef.mcpServer } : {}),
|
|
256
|
+
...(ctx?.context?.isGroupChat !== undefined ? { isGroupChat: (ctx?.context).isGroupChat } : {}),
|
|
257
|
+
};
|
|
258
|
+
const guardArgs = normalizeGuardArgs(name, args);
|
|
259
|
+
const guardResult = (0, guardrails_1.guardInvocation)(name, guardArgs, guardContext);
|
|
260
|
+
if (!guardResult.allowed) {
|
|
261
|
+
(0, runtime_1.emitNervesEvent)({
|
|
262
|
+
level: "warn",
|
|
263
|
+
event: "tool.guardrail_block",
|
|
264
|
+
component: "tools",
|
|
265
|
+
message: "guardrail blocked tool execution",
|
|
266
|
+
meta: { name, reason: guardResult.reason },
|
|
267
|
+
});
|
|
268
|
+
return guardResult.reason;
|
|
269
|
+
}
|
|
140
270
|
try {
|
|
141
271
|
const result = await def.handler(args, ctx);
|
|
142
272
|
(0, runtime_1.emitNervesEvent)({
|
|
@@ -179,65 +309,47 @@ function summarizeUnknownArgs(args) {
|
|
|
179
309
|
return summarizeKeyValues(args, keys);
|
|
180
310
|
}
|
|
181
311
|
function summarizeArgs(name, args) {
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
// Check github tools
|
|
187
|
-
const githubSummary = (0, tools_github_1.summarizeGithubArgs)(name, args);
|
|
188
|
-
if (githubSummary !== undefined)
|
|
189
|
-
return githubSummary;
|
|
190
|
-
// Base tools
|
|
191
|
-
if (name === "read_file" || name === "write_file")
|
|
192
|
-
return summarizeKeyValues(args, ["path"]);
|
|
193
|
-
if (name === "edit_file")
|
|
194
|
-
return summarizeKeyValues(args, ["path"]);
|
|
195
|
-
if (name === "glob")
|
|
196
|
-
return summarizeKeyValues(args, ["pattern", "cwd"]);
|
|
197
|
-
if (name === "grep")
|
|
198
|
-
return summarizeKeyValues(args, ["pattern", "path", "include"]);
|
|
199
|
-
if (name === "shell")
|
|
200
|
-
return summarizeKeyValues(args, ["command"]);
|
|
201
|
-
if (name === "load_skill")
|
|
202
|
-
return summarizeKeyValues(args, ["name"]);
|
|
203
|
-
if (name === "coding_spawn")
|
|
204
|
-
return summarizeKeyValues(args, ["runner", "workdir", "taskRef"]);
|
|
205
|
-
if (name === "coding_status")
|
|
206
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
207
|
-
if (name === "coding_tail")
|
|
208
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
209
|
-
if (name === "coding_send_input")
|
|
210
|
-
return summarizeKeyValues(args, ["sessionId", "input"]);
|
|
211
|
-
if (name === "coding_kill")
|
|
212
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
213
|
-
if (name === "bluebubbles_set_reply_target")
|
|
214
|
-
return summarizeKeyValues(args, ["target", "threadOriginatorGuid"]);
|
|
215
|
-
if (name === "set_reasoning_effort")
|
|
216
|
-
return summarizeKeyValues(args, ["level"]);
|
|
217
|
-
if (name === "claude")
|
|
218
|
-
return summarizeKeyValues(args, ["prompt"]);
|
|
219
|
-
if (name === "web_search")
|
|
220
|
-
return summarizeKeyValues(args, ["query"]);
|
|
221
|
-
if (name === "memory_search")
|
|
222
|
-
return summarizeKeyValues(args, ["query"]);
|
|
223
|
-
if (name === "memory_save")
|
|
224
|
-
return summarizeKeyValues(args, ["text", "about"]);
|
|
225
|
-
if (name === "get_friend_note")
|
|
226
|
-
return summarizeKeyValues(args, ["friendId"]);
|
|
227
|
-
if (name === "save_friend_note") {
|
|
228
|
-
return summarizeKeyValues(args, ["type", "key", "content"]);
|
|
229
|
-
}
|
|
230
|
-
if (name === "bridge_manage")
|
|
231
|
-
return summarizeKeyValues(args, ["action", "bridgeId", "objective", "friendId", "channel", "key"]);
|
|
232
|
-
if (name === "ado_backlog_list")
|
|
233
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
234
|
-
if (name === "ado_batch_update")
|
|
235
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
236
|
-
if (name === "ado_create_epic" || name === "ado_create_issue")
|
|
237
|
-
return summarizeKeyValues(args, ["organization", "project", "title"]);
|
|
238
|
-
if (name === "ado_move_items")
|
|
239
|
-
return summarizeKeyValues(args, ["organization", "project", "workItemIds"]);
|
|
240
|
-
if (name === "ado_restructure_backlog")
|
|
241
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
312
|
+
const def = findDefinition(name);
|
|
313
|
+
if (def && def.summaryKeys !== undefined) {
|
|
314
|
+
return summarizeKeyValues(args, def.summaryKeys);
|
|
315
|
+
}
|
|
242
316
|
return summarizeUnknownArgs(args);
|
|
243
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
|
+
}
|