@ouro.bot/cli 0.1.0-alpha.66 → 0.1.0-alpha.661
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 +4216 -13
- package/dist/a2a/card.js +56 -0
- package/dist/a2a/client.js +143 -0
- package/dist/a2a/config.js +50 -0
- package/dist/a2a/onboarding.js +111 -0
- package/dist/a2a/server.js +498 -0
- package/dist/a2a/task-store.js +69 -0
- package/dist/a2a/types.js +3 -0
- 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/flight-recorder.js +369 -0
- package/dist/arc/intentions.js +134 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +292 -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/commerce/store.js +755 -0
- package/dist/commerce/types.js +3 -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 +331 -0
- package/dist/heart/config.js +118 -119
- package/dist/heart/context-loss-gauntlet.js +354 -0
- 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 +523 -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 +7767 -0
- package/dist/heart/daemon/cli-help.js +558 -0
- package/dist/heart/daemon/cli-parse.js +1688 -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 +937 -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 +135 -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 +78 -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 +511 -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 +564 -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 +203 -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 +40 -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 +45 -18
- package/dist/heart/identity.js +174 -57
- package/dist/heart/kept-notes.js +289 -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 +67 -0
- package/dist/heart/mailbox/mailbox-http-response.js +7 -0
- package/dist/heart/mailbox/mailbox-http-routes.js +250 -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 +32 -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 +324 -0
- package/dist/heart/mailbox/readers/mail.js +375 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +728 -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 +696 -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 +17 -4
- package/dist/heart/session-activity.js +48 -24
- package/dist/heart/session-events.js +1133 -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 +351 -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 +155 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +430 -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/heart/work-card.js +386 -0
- package/dist/mailbox-ui/assets/index-B-V9vRQ0.js +61 -0
- package/dist/mailbox-ui/assets/index-BOZbGbkL.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 +21 -2
- package/dist/mind/context.js +250 -101
- package/dist/mind/desk-section.js +362 -0
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +68 -77
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/friends/channel.js +48 -0
- package/dist/mind/friends/resolver.js +107 -4
- package/dist/mind/friends/store-file.js +61 -4
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/{associative-recall.js → note-search.js} +47 -58
- 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 +1015 -140
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/record-paths.js +312 -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 +71 -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 +159 -25
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +434 -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-a2a.js +283 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-awaiting.js +372 -0
- package/dist/repertoire/tools-base.js +63 -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-commerce.js +253 -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 +290 -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 +418 -0
- package/dist/repertoire/tools-obligations.js +143 -0
- package/dist/repertoire/tools-orientation.js +31 -0
- package/dist/repertoire/tools-record.js +469 -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 +224 -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 +243 -79
- 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/a2a-entry.js +78 -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 +122 -0
- package/dist/senses/inner-dialog-worker.js +303 -22
- package/dist/senses/inner-dialog.js +525 -41
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +857 -180
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +419 -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 +69 -0
- package/package.json +55 -12
- package/skills/agent-commerce.md +113 -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/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,25 @@
|
|
|
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 store_1 = require("../commerce/store");
|
|
19
|
+
const tools_surface_1 = require("./tools-surface");
|
|
20
|
+
const mcp_tools_1 = require("./mcp-tools");
|
|
21
|
+
const tools_voice_1 = require("./tools-voice");
|
|
22
|
+
const shell_sessions_1 = require("./shell-sessions");
|
|
16
23
|
function safeGetAgentRoot() {
|
|
17
24
|
try {
|
|
18
25
|
return (0, identity_1.getAgentRoot)();
|
|
@@ -24,9 +31,24 @@ function safeGetAgentRoot() {
|
|
|
24
31
|
// Re-export types and constants used by the rest of the codebase
|
|
25
32
|
var tools_base_2 = require("./tools-base");
|
|
26
33
|
Object.defineProperty(exports, "tools", { enumerable: true, get: function () { return tools_base_2.tools; } });
|
|
27
|
-
Object.defineProperty(exports, "
|
|
34
|
+
Object.defineProperty(exports, "settleTool", { enumerable: true, get: function () { return tools_base_2.settleTool; } });
|
|
35
|
+
Object.defineProperty(exports, "observeTool", { enumerable: true, get: function () { return tools_base_2.observeTool; } });
|
|
36
|
+
Object.defineProperty(exports, "ponderTool", { enumerable: true, get: function () { return tools_base_2.ponderTool; } });
|
|
37
|
+
Object.defineProperty(exports, "restTool", { enumerable: true, get: function () { return tools_base_2.restTool; } });
|
|
38
|
+
Object.defineProperty(exports, "speakTool", { enumerable: true, get: function () { return tools_base_2.speakTool; } });
|
|
39
|
+
// Re-export surface tool schema for consumers (e.g. heart/core.ts)
|
|
40
|
+
var tools_surface_2 = require("./tools-surface");
|
|
41
|
+
Object.defineProperty(exports, "surfaceToolDef", { enumerable: true, get: function () { return tools_surface_2.surfaceToolDef; } });
|
|
28
42
|
// 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];
|
|
43
|
+
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];
|
|
44
|
+
const COMMERCE_AUTHORITY_TOOLS = new Set(["stripe_create_card", "flight_hold", "flight_book"]);
|
|
45
|
+
// MCP tool definitions — populated each time getToolsForChannel() is called with an mcpManager.
|
|
46
|
+
// Kept separate from allDefinitions so execTool can find them.
|
|
47
|
+
let mcpDefinitions = [];
|
|
48
|
+
/** Exported for testing — reset the MCP definitions cache. */
|
|
49
|
+
function resetMcpDefinitions() {
|
|
50
|
+
mcpDefinitions = [];
|
|
51
|
+
}
|
|
30
52
|
function baseToolsForCapabilities() {
|
|
31
53
|
// Use baseToolDefinitions at call time so dynamically-added tools are included
|
|
32
54
|
return tools_base_1.baseToolDefinitions.map((d) => d.tool);
|
|
@@ -57,14 +79,17 @@ function filterByCapability(toolList, providerCapabilities) {
|
|
|
57
79
|
// Teams/integration tools are included only if their integration is in availableIntegrations.
|
|
58
80
|
// When toolPreferences is provided, matching preferences are appended to tool descriptions.
|
|
59
81
|
// When providerCapabilities is provided, tools with requiredCapability are filtered.
|
|
60
|
-
function getToolsForChannel(capabilities, toolPreferences, _context, providerCapabilities) {
|
|
82
|
+
function getToolsForChannel(capabilities, toolPreferences, _context, providerCapabilities, mcpManager, _chatModel) {
|
|
61
83
|
const baseTools = baseToolsForCapabilities();
|
|
62
84
|
const bluebubblesTools = capabilities?.channel === "bluebubbles"
|
|
63
85
|
? tools_bluebubbles_1.bluebubblesToolDefinitions.map((d) => d.tool)
|
|
64
86
|
: [];
|
|
87
|
+
const voiceTools = capabilities?.channel === "voice"
|
|
88
|
+
? tools_voice_1.voiceToolDefinitions.map((d) => d.tool)
|
|
89
|
+
: [];
|
|
65
90
|
let result;
|
|
66
91
|
if (!capabilities || capabilities.availableIntegrations.length === 0) {
|
|
67
|
-
result = [...baseTools, ...bluebubblesTools];
|
|
92
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools];
|
|
68
93
|
}
|
|
69
94
|
else {
|
|
70
95
|
const available = new Set(capabilities.availableIntegrations);
|
|
@@ -72,7 +97,7 @@ function getToolsForChannel(capabilities, toolPreferences, _context, providerCap
|
|
|
72
97
|
// Include tools whose integration is available, plus channel tools with no integration gate (e.g. teams_send_message)
|
|
73
98
|
const integrationDefs = channelDefs.filter((d) => d.integration ? available.has(d.integration) : capabilities.channel === "teams");
|
|
74
99
|
if (!toolPreferences || Object.keys(toolPreferences).length === 0) {
|
|
75
|
-
result = [...baseTools, ...bluebubblesTools, ...integrationDefs.map((d) => d.tool)];
|
|
100
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools, ...integrationDefs.map((d) => d.tool)];
|
|
76
101
|
}
|
|
77
102
|
else {
|
|
78
103
|
// Build a map of integration -> preference text for fast lookup
|
|
@@ -86,26 +111,118 @@ function getToolsForChannel(capabilities, toolPreferences, _context, providerCap
|
|
|
86
111
|
const pref = prefMap.get(d.integration);
|
|
87
112
|
return pref ? applyPreference(d.tool, pref) : d.tool;
|
|
88
113
|
});
|
|
89
|
-
result = [...baseTools, ...bluebubblesTools, ...enrichedIntegrationTools];
|
|
114
|
+
result = [...baseTools, ...bluebubblesTools, ...voiceTools, ...enrichedIntegrationTools];
|
|
90
115
|
}
|
|
91
116
|
}
|
|
117
|
+
// Append first-class MCP tools when mcpManager is provided
|
|
118
|
+
if (mcpManager) {
|
|
119
|
+
mcpDefinitions = (0, mcp_tools_1.mcpToolsAsDefinitions)(mcpManager);
|
|
120
|
+
const mcpSchemas = mcpDefinitions.map((d) => d.tool);
|
|
121
|
+
result = [...result, ...mcpSchemas];
|
|
122
|
+
}
|
|
92
123
|
return filterByCapability(result, providerCapabilities);
|
|
93
124
|
}
|
|
94
|
-
//
|
|
95
|
-
|
|
96
|
-
function
|
|
97
|
-
|
|
98
|
-
|
|
125
|
+
// Look up a tool definition from the combined registry (native + MCP).
|
|
126
|
+
function findDefinition(toolName) {
|
|
127
|
+
return allDefinitions.find((d) => d.tool.function.name === toolName)
|
|
128
|
+
?? mcpDefinitions.find((d) => d.tool.function.name === toolName);
|
|
129
|
+
}
|
|
130
|
+
function normalizeGuardArgs(_name, args) {
|
|
131
|
+
return args;
|
|
132
|
+
}
|
|
133
|
+
const READ_ONLY_OURO_SHELL_COMMANDS = new Set([
|
|
134
|
+
"help",
|
|
135
|
+
"-h",
|
|
136
|
+
"--help",
|
|
137
|
+
"-v",
|
|
138
|
+
"--version",
|
|
139
|
+
"status",
|
|
140
|
+
"whoami",
|
|
141
|
+
"versions",
|
|
142
|
+
"changelog",
|
|
143
|
+
"mailbox",
|
|
144
|
+
"inner",
|
|
145
|
+
"thoughts",
|
|
146
|
+
"check",
|
|
147
|
+
"session list",
|
|
148
|
+
"mcp list",
|
|
149
|
+
"config models",
|
|
150
|
+
"auth verify",
|
|
151
|
+
"vault status",
|
|
152
|
+
"vault config status",
|
|
153
|
+
"vault item status",
|
|
154
|
+
"vault item list",
|
|
155
|
+
]);
|
|
156
|
+
function shellTokens(command) {
|
|
157
|
+
return command.trim().split(/\s+/).filter(Boolean);
|
|
158
|
+
}
|
|
159
|
+
function ouroShellRiskReason(command) {
|
|
160
|
+
const tokens = shellTokens(command);
|
|
161
|
+
if (tokens[0] !== "ouro")
|
|
162
|
+
return null;
|
|
163
|
+
const first = tokens[1] ?? "";
|
|
164
|
+
const second = tokens[2] ?? "";
|
|
165
|
+
const third = tokens[3] ?? "";
|
|
166
|
+
const twoWord = second ? `${first} ${second}` : first;
|
|
167
|
+
const threeWord = third ? `${twoWord} ${third}` : twoWord;
|
|
168
|
+
if (READ_ONLY_OURO_SHELL_COMMANDS.has(threeWord)
|
|
169
|
+
|| READ_ONLY_OURO_SHELL_COMMANDS.has(twoWord)
|
|
170
|
+
|| READ_ONLY_OURO_SHELL_COMMANDS.has(first)) {
|
|
171
|
+
return null;
|
|
172
|
+
}
|
|
173
|
+
const hint = first === "restart_runtime"
|
|
174
|
+
? " Hint: use the restart_runtime tool instead of shell."
|
|
175
|
+
: "";
|
|
176
|
+
return `ouro CLI command may mutate runtime/config state or be unavailable from shell.${hint}`;
|
|
177
|
+
}
|
|
178
|
+
function shellRiskProfile(args) {
|
|
179
|
+
const command = String(args.command);
|
|
180
|
+
const destructive = (0, shell_sessions_1.detectDestructivePatterns)(command);
|
|
181
|
+
if (destructive.length > 0) {
|
|
182
|
+
return { mutates: "external_side_effect", risk: "high", reason: `destructive shell pattern: ${destructive.join(", ")}` };
|
|
183
|
+
}
|
|
184
|
+
const ouroRiskReason = ouroShellRiskReason(command);
|
|
185
|
+
if (ouroRiskReason) {
|
|
186
|
+
return { mutates: "external_side_effect", risk: "high", reason: ouroRiskReason };
|
|
187
|
+
}
|
|
188
|
+
if (/(^|\s)(rm|mv|cp|touch|mkdir|rmdir)\b/.test(command)
|
|
189
|
+
|| /(^|\s)(npm|pnpm|yarn)\s+(install|add|remove|update|upgrade)\b/.test(command)
|
|
190
|
+
|| /(^|\s)git\s+(add|apply|checkout|clean|commit|merge|pull|push|rebase|reset|restore|switch)\b/.test(command)
|
|
191
|
+
|| /(^|\s)(sed\s+-i|perl\s+-pi)\b/.test(command)
|
|
192
|
+
|| /(^|\s)(tee|truncate)\b/.test(command)
|
|
193
|
+
|| /(^|[^<])>>?\s*\S+/.test(command)) {
|
|
194
|
+
return { mutates: "external_side_effect", risk: "high", reason: "shell command appears to mutate files, packages, git state, or external state" };
|
|
195
|
+
}
|
|
196
|
+
return { mutates: "none", risk: "low" };
|
|
197
|
+
}
|
|
198
|
+
function riskProfileForTool(def, name, args) {
|
|
199
|
+
if (name === "shell")
|
|
200
|
+
return shellRiskProfile(args);
|
|
201
|
+
if (typeof def.riskProfile === "function")
|
|
202
|
+
return def.riskProfile(args);
|
|
203
|
+
return def.riskProfile ?? { mutates: "none", risk: "low" };
|
|
204
|
+
}
|
|
205
|
+
function orientationHoldMessage(name, profile, reason) {
|
|
206
|
+
return `orientation hold: ${reason} Available: orientation_get plus read-only inspection tools like trip_status, query_session, read_config, read_file, grep, search_facts, consult_diary, and consult_notes. Resolve the referent/correction, then retry ${name} if the action is still correct. Blocked ${mutationKindsFor(profile).join(", ")}. ${profile.reason}.`;
|
|
207
|
+
}
|
|
208
|
+
function mutationKindsFor(profile) {
|
|
209
|
+
const mutates = profile.mutates;
|
|
210
|
+
return typeof mutates === "string" ? [mutates] : [...mutates];
|
|
211
|
+
}
|
|
212
|
+
function orientationPolicyBlocks(profile, blockedMutationKinds) {
|
|
213
|
+
if (profile.risk !== "high")
|
|
214
|
+
return false;
|
|
215
|
+
return mutationKindsFor(profile).some((kind) => blockedMutationKinds.includes(kind));
|
|
99
216
|
}
|
|
100
217
|
async function execTool(name, args, ctx) {
|
|
101
218
|
(0, runtime_1.emitNervesEvent)({
|
|
102
219
|
event: "tool.start",
|
|
103
220
|
component: "tools",
|
|
104
221
|
message: "tool execution started",
|
|
105
|
-
meta: { name },
|
|
222
|
+
meta: { name, ...(name === "shell" && args.command ? { command: args.command } : {}) },
|
|
106
223
|
});
|
|
107
|
-
// Look up from combined registry
|
|
108
|
-
const def =
|
|
224
|
+
// Look up from combined registry (native + MCP)
|
|
225
|
+
const def = findDefinition(name);
|
|
109
226
|
if (!def) {
|
|
110
227
|
(0, runtime_1.emitNervesEvent)({
|
|
111
228
|
level: "error",
|
|
@@ -116,13 +233,33 @@ async function execTool(name, args, ctx) {
|
|
|
116
233
|
});
|
|
117
234
|
return `unknown: ${name}`;
|
|
118
235
|
}
|
|
236
|
+
const riskProfile = riskProfileForTool(def, name, args);
|
|
237
|
+
const orientationPolicy = ctx?.orientationFrame?.actionPolicy;
|
|
238
|
+
if (orientationPolicy?.mode === "correction_hold"
|
|
239
|
+
&& orientationPolicyBlocks(riskProfile, orientationPolicy.blockedMutationKinds)) {
|
|
240
|
+
const reason = orientationPolicy.reason;
|
|
241
|
+
const message = orientationHoldMessage(name, riskProfile, reason);
|
|
242
|
+
(0, runtime_1.emitNervesEvent)({
|
|
243
|
+
level: "warn",
|
|
244
|
+
event: "tool.orientation_hold_block",
|
|
245
|
+
component: "tools",
|
|
246
|
+
message: "orientation hold blocked high-risk tool execution",
|
|
247
|
+
meta: { name, mutates: mutationKindsFor(riskProfile), reason },
|
|
248
|
+
});
|
|
249
|
+
return message;
|
|
250
|
+
}
|
|
119
251
|
// Guardrail check: structural + trust-level
|
|
252
|
+
const mcpDef = mcpDefinitions.find((d) => d.tool.function.name === name);
|
|
120
253
|
const guardContext = {
|
|
121
254
|
readPaths: tools_base_1.editFileReadTracker,
|
|
122
255
|
trustLevel: ctx?.context?.friend?.trustLevel,
|
|
123
|
-
agentRoot: safeGetAgentRoot(),
|
|
256
|
+
agentRoot: ctx?.agentRoot ?? safeGetAgentRoot(),
|
|
257
|
+
friendId: ctx?.context?.friend?.id,
|
|
258
|
+
...(mcpDef?.mcpServer ? { mcpServerName: mcpDef.mcpServer } : {}),
|
|
259
|
+
...(ctx?.context?.isGroupChat !== undefined ? { isGroupChat: (ctx?.context).isGroupChat } : {}),
|
|
124
260
|
};
|
|
125
|
-
const
|
|
261
|
+
const guardArgs = normalizeGuardArgs(name, args);
|
|
262
|
+
const guardResult = (0, guardrails_1.guardInvocation)(name, guardArgs, guardContext);
|
|
126
263
|
if (!guardResult.allowed) {
|
|
127
264
|
(0, runtime_1.emitNervesEvent)({
|
|
128
265
|
level: "warn",
|
|
@@ -133,8 +270,37 @@ async function execTool(name, args, ctx) {
|
|
|
133
270
|
});
|
|
134
271
|
return guardResult.reason;
|
|
135
272
|
}
|
|
273
|
+
const commerceReservation = COMMERCE_AUTHORITY_TOOLS.has(name) && guardContext.agentRoot
|
|
274
|
+
? (0, store_1.reserveCommerceAuthority)({
|
|
275
|
+
agentRoot: guardContext.agentRoot,
|
|
276
|
+
token: guardArgs.commerce_authority,
|
|
277
|
+
toolName: name,
|
|
278
|
+
args: guardArgs,
|
|
279
|
+
friendId: guardContext.friendId,
|
|
280
|
+
})
|
|
281
|
+
: null;
|
|
282
|
+
if (commerceReservation && !commerceReservation.ok) {
|
|
283
|
+
(0, runtime_1.emitNervesEvent)({
|
|
284
|
+
level: "warn",
|
|
285
|
+
event: "tool.guardrail_block",
|
|
286
|
+
component: "tools",
|
|
287
|
+
message: "guardrail blocked tool execution",
|
|
288
|
+
meta: { name, reason: commerceReservation.reason },
|
|
289
|
+
});
|
|
290
|
+
return `commerce authority required: ${commerceReservation.reason}`;
|
|
291
|
+
}
|
|
292
|
+
const toolContext = commerceReservation?.ok
|
|
293
|
+
? {
|
|
294
|
+
...ctx,
|
|
295
|
+
agentRoot: guardContext.agentRoot,
|
|
296
|
+
commerceAuthority: {
|
|
297
|
+
checkoutId: commerceReservation.checkoutId,
|
|
298
|
+
reservationToken: commerceReservation.reservationToken,
|
|
299
|
+
},
|
|
300
|
+
}
|
|
301
|
+
: ctx;
|
|
136
302
|
try {
|
|
137
|
-
const result = await def.handler(args,
|
|
303
|
+
const result = await def.handler(args, toolContext);
|
|
138
304
|
(0, runtime_1.emitNervesEvent)({
|
|
139
305
|
event: "tool.end",
|
|
140
306
|
component: "tools",
|
|
@@ -153,6 +319,22 @@ async function execTool(name, args, ctx) {
|
|
|
153
319
|
});
|
|
154
320
|
throw error;
|
|
155
321
|
}
|
|
322
|
+
finally {
|
|
323
|
+
if (commerceReservation?.ok && guardContext.agentRoot) {
|
|
324
|
+
try {
|
|
325
|
+
(0, store_1.releaseReservedCommerceAuthority)({
|
|
326
|
+
agentRoot: guardContext.agentRoot,
|
|
327
|
+
checkoutId: commerceReservation.checkoutId,
|
|
328
|
+
reservationToken: commerceReservation.reservationToken,
|
|
329
|
+
toolName: name,
|
|
330
|
+
friendId: guardContext.friendId,
|
|
331
|
+
});
|
|
332
|
+
}
|
|
333
|
+
catch {
|
|
334
|
+
/* v8 ignore next -- external tool result/error should not be masked by best-effort reservation cleanup @preserve */
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
}
|
|
156
338
|
}
|
|
157
339
|
function summarizeKeyValues(args, keys, maxValueLength = 60) {
|
|
158
340
|
const parts = [];
|
|
@@ -175,65 +357,47 @@ function summarizeUnknownArgs(args) {
|
|
|
175
357
|
return summarizeKeyValues(args, keys);
|
|
176
358
|
}
|
|
177
359
|
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"]);
|
|
360
|
+
const def = findDefinition(name);
|
|
361
|
+
if (def && def.summaryKeys !== undefined) {
|
|
362
|
+
return summarizeKeyValues(args, def.summaryKeys);
|
|
363
|
+
}
|
|
238
364
|
return summarizeUnknownArgs(args);
|
|
239
365
|
}
|
|
366
|
+
/**
|
|
367
|
+
* Build an enriched tool result summary for display on remote channels.
|
|
368
|
+
* For recognized tools, includes result-derived info (diff stats, exit codes, etc.).
|
|
369
|
+
* Falls back to arg-based summary for unrecognized tools.
|
|
370
|
+
*/
|
|
371
|
+
function buildToolResultSummary(name, args, _result, success) {
|
|
372
|
+
/* v8 ignore start -- branches: ?? fallbacks and ternaries in tool summary formatting @preserve */
|
|
373
|
+
switch (name) {
|
|
374
|
+
case "edit_file": {
|
|
375
|
+
if (!success)
|
|
376
|
+
return summarizeArgs(name, args);
|
|
377
|
+
const addedLines = (args.new_string ?? "").split("\n").length;
|
|
378
|
+
const removedLines = (args.old_string ?? "").split("\n").length;
|
|
379
|
+
return `+${addedLines} -${removedLines} lines in ${args.path ?? "unknown"}`;
|
|
380
|
+
}
|
|
381
|
+
case "shell": {
|
|
382
|
+
const cmd = args.command ?? "?";
|
|
383
|
+
const exitCode = success ? 0 : 1;
|
|
384
|
+
return `$ ${cmd} (exit ${exitCode})`;
|
|
385
|
+
}
|
|
386
|
+
case "read_file":
|
|
387
|
+
return `path=${args.path ?? "unknown"}`;
|
|
388
|
+
case "write_file":
|
|
389
|
+
return `path=${args.path ?? "unknown"}`;
|
|
390
|
+
case "glob":
|
|
391
|
+
return `pattern=${args.pattern ?? "?"} ${args.cwd ? `cwd=${args.cwd}` : ""}`.trim();
|
|
392
|
+
case "grep":
|
|
393
|
+
return `pattern=${args.pattern ?? "?"} ${args.path ? `path=${args.path}` : ""}`.trim();
|
|
394
|
+
case "coding_spawn": {
|
|
395
|
+
const taskRef = args.taskRef ?? "unknown";
|
|
396
|
+
const status = success ? "spawned" : "failed";
|
|
397
|
+
return `${taskRef} -> ${status}`;
|
|
398
|
+
}
|
|
399
|
+
default:
|
|
400
|
+
return summarizeArgs(name, args);
|
|
401
|
+
}
|
|
402
|
+
/* v8 ignore stop */
|
|
403
|
+
}
|