@ouro.bot/cli 0.1.0-alpha.56 → 0.1.0-alpha.561
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 +3604 -0
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +140 -0
- package/dist/arc/episodes.js +117 -0
- package/dist/arc/intentions.js +133 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +237 -0
- package/dist/arc/packets.js +193 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +65 -0
- package/dist/heart/active-work.js +837 -26
- package/dist/heart/agent-entry.js +58 -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/adapter.js +2 -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/background-operations.js +281 -0
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +111 -0
- package/dist/heart/config-registry.js +322 -0
- package/dist/heart/config.js +114 -118
- package/dist/heart/core.js +913 -246
- 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-exec.js +7457 -0
- package/dist/heart/daemon/cli-help.js +498 -0
- package/dist/heart/daemon/cli-parse.js +1592 -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 -1698
- package/dist/heart/daemon/daemon-entry.js +387 -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 +796 -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 +826 -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 +82 -12
- 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 +2 -2
- 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/process-manager.js +375 -33
- 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 +67 -16
- package/dist/heart/daemon/runtime-metadata.js +3 -31
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +389 -38
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +94 -0
- 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 +3 -25
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +162 -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 -1
- 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 +35 -12
- package/dist/heart/identity.js +203 -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 +195 -0
- package/dist/heart/mailbox/readers/agent-machine.js +382 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
- package/dist/heart/mailbox/readers/mail.js +362 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +651 -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 +683 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +19 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +267 -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 +97 -13
- 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 +43 -22
- package/dist/heart/session-events.js +1149 -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 +243 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +44 -27
- 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 +139 -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-B-461hes.js +61 -0
- package/dist/mailbox-ui/assets/index-BPr5vNuM.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 +674 -0
- package/dist/mailroom/body-cache.js +61 -0
- package/dist/mailroom/core.js +720 -0
- package/dist/mailroom/entry.js +160 -0
- package/dist/mailroom/file-store.js +430 -0
- package/dist/mailroom/mbox-import.js +383 -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 +256 -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 +7 -1
- package/dist/mind/context.js +165 -101
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +62 -75
- 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 +39 -3
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/journal-index.js +161 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +4 -0
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1011 -123
- 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 +129 -5
- package/dist/nerves/coverage/run-artifacts.js +1 -1
- 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 +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +963 -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 +330 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +158 -9
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +170 -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/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 +396 -0
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +362 -0
- package/dist/repertoire/mcp-tools.js +63 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +15 -24
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tasks/board.js +31 -5
- package/dist/repertoire/tasks/fix.js +182 -0
- package/dist/repertoire/tasks/index.js +16 -4
- package/dist/repertoire/tasks/lifecycle.js +2 -2
- package/dist/repertoire/tasks/parser.js +3 -2
- package/dist/repertoire/tasks/scanner.js +194 -37
- package/dist/repertoire/tasks/transitions.js +16 -78
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-base.js +47 -1075
- package/dist/repertoire/tools-bluebubbles.js +1 -0
- package/dist/repertoire/tools-bridge.js +142 -0
- package/dist/repertoire/tools-bundle.js +984 -0
- package/dist/repertoire/tools-config.js +185 -0
- package/dist/repertoire/tools-continuity.js +248 -0
- package/dist/repertoire/tools-credential.js +381 -0
- package/dist/repertoire/tools-files.js +342 -0
- package/dist/repertoire/tools-flight.js +224 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +1 -7
- package/dist/repertoire/tools-mail.js +1857 -0
- package/dist/repertoire/tools-notes.js +421 -0
- package/dist/repertoire/tools-session.js +750 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +180 -0
- package/dist/repertoire/tools-surface.js +243 -0
- package/dist/repertoire/tools-teams.js +9 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +604 -0
- package/dist/repertoire/tools-user-profile.js +144 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools.js +108 -100
- 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 +116 -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 +2305 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
- 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/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 +187 -0
- package/dist/senses/cli.js +520 -209
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +175 -21
- package/dist/senses/inner-dialog.js +330 -27
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +549 -181
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +251 -0
- package/dist/senses/surface-tool.js +68 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +387 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/senses/voice/audio-routing.js +119 -0
- package/dist/senses/voice/elevenlabs.js +178 -0
- package/dist/senses/voice/golden-path.js +116 -0
- package/dist/senses/voice/index.js +26 -0
- package/dist/senses/voice/meeting.js +113 -0
- package/dist/senses/voice/playback.js +139 -0
- package/dist/senses/voice/transcript.js +70 -0
- package/dist/senses/voice/turn.js +85 -0
- package/dist/senses/voice/types.js +2 -0
- package/dist/senses/voice/whisper.js +161 -0
- package/dist/senses/voice-entry.js +80 -0
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +146 -0
- package/package.json +38 -7
- 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 +101 -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/subagent-installer.js +0 -166
- package/dist/heart/session-recall.js +0 -116
- package/dist/mind/associative-recall.js +0 -209
- 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 -86
- package/subagents/work-doer.md +0 -237
- package/subagents/work-merger.md +0 -618
- package/subagents/work-planner.md +0 -390
- /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/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
|
@@ -0,0 +1,683 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports._senseTurnCommandTimeoutMs = exports._senseTurnRetryDelays = exports.SENSE_TURN_COMMAND_TIMEOUT_MS = exports.SENSE_TURN_RETRY_DELAYS_MS = exports.SENSE_TURN_MAX_RETRIES = void 0;
|
|
37
|
+
exports._setSenseTurnRetryDelays = _setSenseTurnRetryDelays;
|
|
38
|
+
exports._setSenseTurnCommandTimeoutMs = _setSenseTurnCommandTimeoutMs;
|
|
39
|
+
exports.createMcpServer = createMcpServer;
|
|
40
|
+
exports.getToolSchemas = getToolSchemas;
|
|
41
|
+
const socket_client_1 = require("../daemon/socket-client");
|
|
42
|
+
const agentService = __importStar(require("../daemon/agent-service"));
|
|
43
|
+
const runtime_1 = require("../../nerves/runtime");
|
|
44
|
+
const session_id_resolver_1 = require("../daemon/session-id-resolver");
|
|
45
|
+
const pending_1 = require("../../mind/pending");
|
|
46
|
+
exports.SENSE_TURN_MAX_RETRIES = 3;
|
|
47
|
+
exports.SENSE_TURN_RETRY_DELAYS_MS = [1000, 2000, 4000];
|
|
48
|
+
exports.SENSE_TURN_COMMAND_TIMEOUT_MS = 10 * 60 * 1000;
|
|
49
|
+
// Allow test override
|
|
50
|
+
exports._senseTurnRetryDelays = exports.SENSE_TURN_RETRY_DELAYS_MS;
|
|
51
|
+
function _setSenseTurnRetryDelays(delays) { exports._senseTurnRetryDelays = delays; }
|
|
52
|
+
exports._senseTurnCommandTimeoutMs = exports.SENSE_TURN_COMMAND_TIMEOUT_MS;
|
|
53
|
+
function _setSenseTurnCommandTimeoutMs(timeoutMs) { exports._senseTurnCommandTimeoutMs = timeoutMs; }
|
|
54
|
+
async function withSenseTurnTimeout(promise, timeoutMs, command) {
|
|
55
|
+
let timer = null;
|
|
56
|
+
try {
|
|
57
|
+
return await Promise.race([
|
|
58
|
+
promise,
|
|
59
|
+
new Promise((_, reject) => {
|
|
60
|
+
timer = setTimeout(() => {
|
|
61
|
+
const error = new Error(`MCP send_message to ${command.agent} timed out after ${timeoutMs}ms waiting for daemon response; command status is unknown.`);
|
|
62
|
+
(0, runtime_1.emitNervesEvent)({
|
|
63
|
+
level: "error",
|
|
64
|
+
component: "daemon",
|
|
65
|
+
event: "daemon.mcp_sense_turn_timeout",
|
|
66
|
+
message: "MCP senseTurn timed out waiting for daemon response",
|
|
67
|
+
meta: { agent: command.agent, friendId: command.friendId, sessionKey: command.sessionKey, timeoutMs },
|
|
68
|
+
});
|
|
69
|
+
reject(error);
|
|
70
|
+
}, timeoutMs);
|
|
71
|
+
}),
|
|
72
|
+
]);
|
|
73
|
+
}
|
|
74
|
+
finally {
|
|
75
|
+
/* v8 ignore next -- Promise.race installs the timer synchronously; null is only a defensive cleanup guard @preserve */
|
|
76
|
+
if (timer)
|
|
77
|
+
clearTimeout(timer);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Send a senseTurn command to the daemon with retry logic.
|
|
82
|
+
* Retries on transient failures: empty response (daemon mid-restart),
|
|
83
|
+
* ECONNREFUSED (daemon not yet listening), ENOENT (socket not yet created).
|
|
84
|
+
*/
|
|
85
|
+
async function sendSenseTurnWithRetry(socketPath, command) {
|
|
86
|
+
let lastError = null;
|
|
87
|
+
/* v8 ignore start -- retry loop: functionally tested via mcp-send-message retry tests @preserve */
|
|
88
|
+
for (let attempt = 0; attempt <= exports.SENSE_TURN_MAX_RETRIES; attempt++) {
|
|
89
|
+
try {
|
|
90
|
+
const response = await withSenseTurnTimeout((0, socket_client_1.sendDaemonCommand)(socketPath, command), exports._senseTurnCommandTimeoutMs, command);
|
|
91
|
+
return response;
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
lastError = error instanceof Error ? error : new Error(String(error));
|
|
95
|
+
const msg = lastError.message;
|
|
96
|
+
const isTransient = msg.includes("ECONNREFUSED")
|
|
97
|
+
|| msg.includes("ENOENT")
|
|
98
|
+
|| msg.includes("empty response")
|
|
99
|
+
|| msg.includes("Empty response");
|
|
100
|
+
if (!isTransient || attempt >= exports.SENSE_TURN_MAX_RETRIES) {
|
|
101
|
+
throw lastError;
|
|
102
|
+
}
|
|
103
|
+
const delay = exports._senseTurnRetryDelays[attempt] ?? 4000;
|
|
104
|
+
(0, runtime_1.emitNervesEvent)({
|
|
105
|
+
component: "daemon",
|
|
106
|
+
event: "daemon.mcp_sense_turn_retry",
|
|
107
|
+
message: `senseTurn attempt ${attempt + 1} failed, retrying in ${delay}ms`,
|
|
108
|
+
meta: { attempt: attempt + 1, error: msg, delay },
|
|
109
|
+
});
|
|
110
|
+
await new Promise((resolve) => setTimeout(resolve, delay));
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
throw lastError ?? new Error("senseTurn failed after retries");
|
|
114
|
+
/* v8 ignore stop */
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Maps MCP tool names to daemon command kinds.
|
|
118
|
+
*/
|
|
119
|
+
const TOOL_TO_COMMAND = {
|
|
120
|
+
ask: "agent.ask",
|
|
121
|
+
status: "agent.status",
|
|
122
|
+
catchup: "agent.catchup",
|
|
123
|
+
delegate: "agent.delegate",
|
|
124
|
+
get_context: "agent.getContext",
|
|
125
|
+
search_notes: "agent.searchNotes",
|
|
126
|
+
get_task: "agent.getTask",
|
|
127
|
+
check_scope: "agent.checkScope",
|
|
128
|
+
request_decision: "agent.requestDecision",
|
|
129
|
+
check_guidance: "agent.checkGuidance",
|
|
130
|
+
report_progress: "agent.reportProgress",
|
|
131
|
+
report_blocker: "agent.reportBlocker",
|
|
132
|
+
report_complete: "agent.reportComplete",
|
|
133
|
+
};
|
|
134
|
+
/**
|
|
135
|
+
* Create an MCP server that speaks JSON-RPC 2.0 over stdio.
|
|
136
|
+
* Handles initialize, initialized, tools/list, and tools/call.
|
|
137
|
+
* Forwards tool calls to the daemon via Unix socket.
|
|
138
|
+
*/
|
|
139
|
+
function createMcpServer(options) {
|
|
140
|
+
const { agent, friendId, socketPath, stdin, stdout } = options;
|
|
141
|
+
let buffer = "";
|
|
142
|
+
let running = false;
|
|
143
|
+
let useContentLengthFraming = true; // default to Content-Length, auto-detect from first message
|
|
144
|
+
// Resolve session ID once per MCP server instance for conversation continuity
|
|
145
|
+
const sessionId = (0, session_id_resolver_1.resolveSessionId)();
|
|
146
|
+
function writeResponse(response) {
|
|
147
|
+
const body = JSON.stringify(response);
|
|
148
|
+
if (useContentLengthFraming) {
|
|
149
|
+
const header = `Content-Length: ${Buffer.byteLength(body)}\r\n\r\n`;
|
|
150
|
+
stdout.write(header + body);
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
stdout.write(body + "\n");
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
function tryParseContentLength() {
|
|
157
|
+
const headerEnd = buffer.indexOf("\r\n\r\n");
|
|
158
|
+
/* v8 ignore start -- partial header delivery only in real I/O */
|
|
159
|
+
if (headerEnd === -1)
|
|
160
|
+
return false;
|
|
161
|
+
/* v8 ignore stop */
|
|
162
|
+
const headerSection = buffer.slice(0, headerEnd);
|
|
163
|
+
const contentLengthMatch = headerSection.match(/Content-Length:\s*(\d+)/i);
|
|
164
|
+
if (!contentLengthMatch) {
|
|
165
|
+
buffer = buffer.slice(headerEnd + 4);
|
|
166
|
+
return true; // consumed invalid header, try again
|
|
167
|
+
}
|
|
168
|
+
const contentLength = parseInt(contentLengthMatch[1], 10);
|
|
169
|
+
const bodyStart = headerEnd + 4;
|
|
170
|
+
/* v8 ignore start -- partial body delivery only in real I/O */
|
|
171
|
+
if (buffer.length < bodyStart + contentLength)
|
|
172
|
+
return false;
|
|
173
|
+
/* v8 ignore stop */
|
|
174
|
+
const body = buffer.slice(bodyStart, bodyStart + contentLength);
|
|
175
|
+
buffer = buffer.slice(bodyStart + contentLength);
|
|
176
|
+
parseAndDispatch(body);
|
|
177
|
+
return true;
|
|
178
|
+
}
|
|
179
|
+
function tryParseNewlineDelimited() {
|
|
180
|
+
const newlineIdx = buffer.indexOf("\n");
|
|
181
|
+
/* v8 ignore start -- partial line delivery only in real I/O */
|
|
182
|
+
if (newlineIdx === -1)
|
|
183
|
+
return false;
|
|
184
|
+
/* v8 ignore stop */
|
|
185
|
+
const line = buffer.slice(0, newlineIdx).trim();
|
|
186
|
+
buffer = buffer.slice(newlineIdx + 1);
|
|
187
|
+
if (line.length === 0)
|
|
188
|
+
return true; // skip blank lines
|
|
189
|
+
parseAndDispatch(line);
|
|
190
|
+
return true;
|
|
191
|
+
}
|
|
192
|
+
function parseAndDispatch(body) {
|
|
193
|
+
let request;
|
|
194
|
+
try {
|
|
195
|
+
request = JSON.parse(body);
|
|
196
|
+
}
|
|
197
|
+
catch {
|
|
198
|
+
writeResponse({
|
|
199
|
+
jsonrpc: "2.0",
|
|
200
|
+
id: null,
|
|
201
|
+
error: { code: -32700, message: "Parse error" },
|
|
202
|
+
});
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
void handleRequest(request);
|
|
206
|
+
}
|
|
207
|
+
let framingDetected = false;
|
|
208
|
+
function handleData(chunk) {
|
|
209
|
+
buffer += chunk.toString("utf-8");
|
|
210
|
+
// Auto-detect framing from first message and mirror it in responses
|
|
211
|
+
if (!framingDetected && buffer.length > 0) {
|
|
212
|
+
useContentLengthFraming = buffer.startsWith("Content-Length:");
|
|
213
|
+
framingDetected = true;
|
|
214
|
+
}
|
|
215
|
+
// Support both Content-Length framing (Claude Code) and newline-delimited JSON (Codex)
|
|
216
|
+
while (buffer.length > 0) {
|
|
217
|
+
const hasContentLength = buffer.startsWith("Content-Length:");
|
|
218
|
+
const parsed = hasContentLength ? tryParseContentLength() : tryParseNewlineDelimited();
|
|
219
|
+
/* v8 ignore start -- break on partial message only in real I/O */
|
|
220
|
+
if (!parsed)
|
|
221
|
+
break;
|
|
222
|
+
/* v8 ignore stop */
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
async function handleRequest(request) {
|
|
226
|
+
(0, runtime_1.emitNervesEvent)({
|
|
227
|
+
component: "daemon",
|
|
228
|
+
event: "daemon.mcp_request_start",
|
|
229
|
+
message: "handling MCP request",
|
|
230
|
+
meta: { method: request.method, agent },
|
|
231
|
+
});
|
|
232
|
+
// Notifications (no id) don't get responses
|
|
233
|
+
if (request.id === undefined) {
|
|
234
|
+
(0, runtime_1.emitNervesEvent)({
|
|
235
|
+
component: "daemon",
|
|
236
|
+
event: "daemon.mcp_request_end",
|
|
237
|
+
message: "handled MCP notification",
|
|
238
|
+
meta: { method: request.method, agent },
|
|
239
|
+
});
|
|
240
|
+
return;
|
|
241
|
+
}
|
|
242
|
+
switch (request.method) {
|
|
243
|
+
case "initialize":
|
|
244
|
+
await handleInitialize(request);
|
|
245
|
+
break;
|
|
246
|
+
case "tools/list":
|
|
247
|
+
handleToolsList(request);
|
|
248
|
+
break;
|
|
249
|
+
case "tools/call":
|
|
250
|
+
await handleToolsCall(request);
|
|
251
|
+
break;
|
|
252
|
+
default:
|
|
253
|
+
writeResponse({
|
|
254
|
+
jsonrpc: "2.0",
|
|
255
|
+
id: request.id,
|
|
256
|
+
error: {
|
|
257
|
+
code: -32601,
|
|
258
|
+
message: `Method not found: ${request.method}`,
|
|
259
|
+
},
|
|
260
|
+
});
|
|
261
|
+
break;
|
|
262
|
+
}
|
|
263
|
+
(0, runtime_1.emitNervesEvent)({
|
|
264
|
+
component: "daemon",
|
|
265
|
+
event: "daemon.mcp_request_end",
|
|
266
|
+
message: "completed MCP request",
|
|
267
|
+
meta: { method: request.method, agent },
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
async function handleInitialize(request) {
|
|
271
|
+
// MCP server works standalone (agent-service reads filesystem directly)
|
|
272
|
+
// Daemon is optional — only needed for commands without a direct service handler
|
|
273
|
+
writeResponse({
|
|
274
|
+
jsonrpc: "2.0",
|
|
275
|
+
id: request.id,
|
|
276
|
+
result: {
|
|
277
|
+
protocolVersion: "2024-11-05",
|
|
278
|
+
serverInfo: {
|
|
279
|
+
name: "ouro-mcp-server",
|
|
280
|
+
version: "0.1.0",
|
|
281
|
+
},
|
|
282
|
+
capabilities: {
|
|
283
|
+
tools: { listChanged: false },
|
|
284
|
+
},
|
|
285
|
+
},
|
|
286
|
+
});
|
|
287
|
+
}
|
|
288
|
+
function handleToolsList(request) {
|
|
289
|
+
const tools = getToolSchemas();
|
|
290
|
+
writeResponse({
|
|
291
|
+
jsonrpc: "2.0",
|
|
292
|
+
id: request.id,
|
|
293
|
+
result: { tools },
|
|
294
|
+
});
|
|
295
|
+
}
|
|
296
|
+
/** Map tool name → agent-service handler function name */
|
|
297
|
+
const TOOL_TO_SERVICE = {
|
|
298
|
+
ask: "handleAgentAsk",
|
|
299
|
+
status: "handleAgentStatus",
|
|
300
|
+
catchup: "handleAgentCatchup",
|
|
301
|
+
delegate: "handleAgentDelegate",
|
|
302
|
+
get_context: "handleAgentGetContext",
|
|
303
|
+
search_notes: "handleAgentSearchNotes",
|
|
304
|
+
get_task: "handleAgentGetTask",
|
|
305
|
+
check_scope: "handleAgentCheckScope",
|
|
306
|
+
request_decision: "handleAgentRequestDecision",
|
|
307
|
+
check_guidance: "handleAgentCheckGuidance",
|
|
308
|
+
report_progress: "handleAgentReportProgress",
|
|
309
|
+
report_blocker: "handleAgentReportBlocker",
|
|
310
|
+
report_complete: "handleAgentReportComplete",
|
|
311
|
+
};
|
|
312
|
+
async function handleToolsCall(request) {
|
|
313
|
+
/* v8 ignore start — ?? fallbacks are defensive; MCP clients always send params */
|
|
314
|
+
const params = request.params ?? {};
|
|
315
|
+
const toolName = params.name;
|
|
316
|
+
const toolArgs = (params.arguments ?? {});
|
|
317
|
+
/* v8 ignore stop */
|
|
318
|
+
// ── Conversation tools: send_message, check_response ──
|
|
319
|
+
if (toolName === "send_message") {
|
|
320
|
+
/* v8 ignore start — ?? fallback defensive; MCP clients always send message */
|
|
321
|
+
const message = toolArgs.message ?? "";
|
|
322
|
+
/* v8 ignore stop */
|
|
323
|
+
try {
|
|
324
|
+
const response = await sendSenseTurnWithRetry(socketPath, {
|
|
325
|
+
kind: "agent.senseTurn",
|
|
326
|
+
agent,
|
|
327
|
+
friendId,
|
|
328
|
+
channel: "mcp",
|
|
329
|
+
sessionKey: sessionId,
|
|
330
|
+
message,
|
|
331
|
+
});
|
|
332
|
+
/* v8 ignore next -- branch: ?? fallback for empty daemon response @preserve */
|
|
333
|
+
const text = response.message ?? "(empty response)";
|
|
334
|
+
writeResponse({
|
|
335
|
+
jsonrpc: "2.0",
|
|
336
|
+
id: request.id,
|
|
337
|
+
result: {
|
|
338
|
+
content: [{ type: "text", text }],
|
|
339
|
+
isError: !response.ok,
|
|
340
|
+
},
|
|
341
|
+
});
|
|
342
|
+
}
|
|
343
|
+
catch (error) {
|
|
344
|
+
/* v8 ignore start — instanceof guard defensive; thrown errors are always Error */
|
|
345
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
346
|
+
/* v8 ignore stop */
|
|
347
|
+
/* v8 ignore start -- daemon-down detection: only triggers with real socket I/O @preserve */
|
|
348
|
+
const isDaemonDown = errorMessage.includes("ECONNREFUSED") || errorMessage.includes("ENOENT");
|
|
349
|
+
const userMessage = isDaemonDown
|
|
350
|
+
? "The daemon is not running. Start it with `ouro up` (production) or `ouro dev` (development), then retry."
|
|
351
|
+
: `Error: ${errorMessage}`;
|
|
352
|
+
/* v8 ignore stop */
|
|
353
|
+
writeResponse({
|
|
354
|
+
jsonrpc: "2.0",
|
|
355
|
+
id: request.id,
|
|
356
|
+
result: {
|
|
357
|
+
content: [{ type: "text", text: userMessage }],
|
|
358
|
+
isError: true,
|
|
359
|
+
},
|
|
360
|
+
});
|
|
361
|
+
}
|
|
362
|
+
return;
|
|
363
|
+
}
|
|
364
|
+
if (toolName === "check_response") {
|
|
365
|
+
const pendingDir = (0, pending_1.getPendingDir)(agent, friendId, "mcp", sessionId);
|
|
366
|
+
const pending = (0, pending_1.drainPending)(pendingDir);
|
|
367
|
+
if (pending.length === 0) {
|
|
368
|
+
writeResponse({
|
|
369
|
+
jsonrpc: "2.0",
|
|
370
|
+
id: request.id,
|
|
371
|
+
result: {
|
|
372
|
+
content: [{ type: "text", text: "no pending messages" }],
|
|
373
|
+
isError: false,
|
|
374
|
+
},
|
|
375
|
+
});
|
|
376
|
+
}
|
|
377
|
+
else {
|
|
378
|
+
const text = pending.map((m) => m.content).join("\n\n---\n\n");
|
|
379
|
+
writeResponse({
|
|
380
|
+
jsonrpc: "2.0",
|
|
381
|
+
id: request.id,
|
|
382
|
+
result: {
|
|
383
|
+
content: [{ type: "text", text }],
|
|
384
|
+
isError: false,
|
|
385
|
+
},
|
|
386
|
+
});
|
|
387
|
+
}
|
|
388
|
+
return;
|
|
389
|
+
}
|
|
390
|
+
// ── delegate: full conversation turn via daemon ──
|
|
391
|
+
if (toolName === "delegate") {
|
|
392
|
+
/* v8 ignore start — ?? fallback defensive; MCP clients always send task */
|
|
393
|
+
const task = toolArgs.task ?? "";
|
|
394
|
+
/* v8 ignore stop */
|
|
395
|
+
const context = toolArgs.context;
|
|
396
|
+
const delegateMessage = context ? `[delegate] ${task}\n\ncontext: ${context}` : `[delegate] ${task}`;
|
|
397
|
+
try {
|
|
398
|
+
const response = await sendSenseTurnWithRetry(socketPath, {
|
|
399
|
+
kind: "agent.senseTurn",
|
|
400
|
+
agent,
|
|
401
|
+
friendId,
|
|
402
|
+
channel: "mcp",
|
|
403
|
+
sessionKey: sessionId,
|
|
404
|
+
message: delegateMessage,
|
|
405
|
+
});
|
|
406
|
+
/* v8 ignore next -- branch: ?? fallback for empty daemon response @preserve */
|
|
407
|
+
const text = response.message ?? "(empty response)";
|
|
408
|
+
writeResponse({
|
|
409
|
+
jsonrpc: "2.0",
|
|
410
|
+
id: request.id,
|
|
411
|
+
result: {
|
|
412
|
+
content: [{ type: "text", text }],
|
|
413
|
+
isError: !response.ok,
|
|
414
|
+
},
|
|
415
|
+
});
|
|
416
|
+
}
|
|
417
|
+
catch (error) {
|
|
418
|
+
/* v8 ignore start — instanceof guard defensive; thrown errors are always Error */
|
|
419
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
420
|
+
/* v8 ignore stop */
|
|
421
|
+
/* v8 ignore start -- daemon-down detection: only triggers with real socket I/O @preserve */
|
|
422
|
+
const isDaemonDown = errorMessage.includes("ECONNREFUSED") || errorMessage.includes("ENOENT");
|
|
423
|
+
const userMessage = isDaemonDown
|
|
424
|
+
? "The daemon is not running. Start it with `ouro up` (production) or `ouro dev` (development), then retry."
|
|
425
|
+
: `Error: ${errorMessage}`;
|
|
426
|
+
/* v8 ignore stop */
|
|
427
|
+
writeResponse({
|
|
428
|
+
jsonrpc: "2.0",
|
|
429
|
+
id: request.id,
|
|
430
|
+
result: {
|
|
431
|
+
content: [{ type: "text", text: userMessage }],
|
|
432
|
+
isError: true,
|
|
433
|
+
},
|
|
434
|
+
});
|
|
435
|
+
}
|
|
436
|
+
return;
|
|
437
|
+
}
|
|
438
|
+
// ── Legacy daemon/service tools ──
|
|
439
|
+
const commandKind = TOOL_TO_COMMAND[toolName];
|
|
440
|
+
if (!commandKind) {
|
|
441
|
+
writeResponse({
|
|
442
|
+
jsonrpc: "2.0",
|
|
443
|
+
id: request.id,
|
|
444
|
+
result: {
|
|
445
|
+
content: [{ type: "text", text: `Unknown tool: ${toolName}` }],
|
|
446
|
+
isError: true,
|
|
447
|
+
},
|
|
448
|
+
});
|
|
449
|
+
return;
|
|
450
|
+
}
|
|
451
|
+
// Call agent-service directly (no daemon roundtrip needed for read-only ops)
|
|
452
|
+
const serviceHandler = TOOL_TO_SERVICE[toolName];
|
|
453
|
+
let response;
|
|
454
|
+
/* v8 ignore start — typeof guard always true; instanceof check defensive; else branch unreachable for known tools */
|
|
455
|
+
if (serviceHandler && typeof agentService[serviceHandler] === "function") {
|
|
456
|
+
const handlerFn = agentService[serviceHandler];
|
|
457
|
+
try {
|
|
458
|
+
response = await handlerFn({ agent, friendId, socketPath, ...toolArgs });
|
|
459
|
+
}
|
|
460
|
+
catch (error) {
|
|
461
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
462
|
+
response = { ok: false, error: `Service error: ${errorMessage}` };
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
else {
|
|
466
|
+
try {
|
|
467
|
+
response = await (0, socket_client_1.sendDaemonCommand)(socketPath, {
|
|
468
|
+
kind: commandKind, agent, friendId, ...toolArgs,
|
|
469
|
+
});
|
|
470
|
+
}
|
|
471
|
+
catch (error) {
|
|
472
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
473
|
+
response = { ok: false, error: `Daemon error: ${errorMessage}` };
|
|
474
|
+
}
|
|
475
|
+
}
|
|
476
|
+
/* v8 ignore stop */
|
|
477
|
+
const text = response.message
|
|
478
|
+
?? response.summary
|
|
479
|
+
?? JSON.stringify(response.data ?? { ok: response.ok });
|
|
480
|
+
writeResponse({
|
|
481
|
+
jsonrpc: "2.0",
|
|
482
|
+
id: request.id,
|
|
483
|
+
result: {
|
|
484
|
+
content: [{ type: "text", text }],
|
|
485
|
+
isError: !response.ok,
|
|
486
|
+
},
|
|
487
|
+
});
|
|
488
|
+
}
|
|
489
|
+
function onData(chunk) {
|
|
490
|
+
handleData(chunk);
|
|
491
|
+
}
|
|
492
|
+
return {
|
|
493
|
+
agent,
|
|
494
|
+
friendId,
|
|
495
|
+
start() {
|
|
496
|
+
if (running)
|
|
497
|
+
return;
|
|
498
|
+
running = true;
|
|
499
|
+
stdin.on("data", onData);
|
|
500
|
+
(0, runtime_1.emitNervesEvent)({
|
|
501
|
+
component: "daemon",
|
|
502
|
+
event: "daemon.mcp_server_start",
|
|
503
|
+
message: "MCP server started",
|
|
504
|
+
meta: { agent, friendId, socketPath },
|
|
505
|
+
});
|
|
506
|
+
},
|
|
507
|
+
stop() {
|
|
508
|
+
if (!running)
|
|
509
|
+
return;
|
|
510
|
+
running = false;
|
|
511
|
+
stdin.removeListener("data", onData);
|
|
512
|
+
// `_end` (not `_stop`) to satisfy the nerves audit's start/end
|
|
513
|
+
// pairing rule — counterpart to `daemon.mcp_server_start`.
|
|
514
|
+
(0, runtime_1.emitNervesEvent)({
|
|
515
|
+
component: "daemon",
|
|
516
|
+
event: "daemon.mcp_server_end",
|
|
517
|
+
message: "MCP server stopped",
|
|
518
|
+
meta: { agent, friendId },
|
|
519
|
+
});
|
|
520
|
+
},
|
|
521
|
+
};
|
|
522
|
+
}
|
|
523
|
+
/**
|
|
524
|
+
* Returns the list of MCP tool schemas for all 15 agent tools.
|
|
525
|
+
* Each schema follows JSON Schema for inputSchema as required by MCP.
|
|
526
|
+
*/
|
|
527
|
+
function getToolSchemas() {
|
|
528
|
+
return [
|
|
529
|
+
{
|
|
530
|
+
name: "ask",
|
|
531
|
+
description: "Ask the agent a question. The agent uses its diary, journal, and recent session context to provide a useful answer.",
|
|
532
|
+
inputSchema: {
|
|
533
|
+
type: "object",
|
|
534
|
+
properties: {
|
|
535
|
+
question: { type: "string", description: "The question to ask the agent" },
|
|
536
|
+
},
|
|
537
|
+
required: ["question"],
|
|
538
|
+
},
|
|
539
|
+
},
|
|
540
|
+
{
|
|
541
|
+
name: "status",
|
|
542
|
+
description: "Get the agent's current status including active sessions, diary and journal state, and activity level.",
|
|
543
|
+
inputSchema: {
|
|
544
|
+
type: "object",
|
|
545
|
+
properties: {},
|
|
546
|
+
},
|
|
547
|
+
},
|
|
548
|
+
{
|
|
549
|
+
name: "catchup",
|
|
550
|
+
description: "Get a summary of the agent's recent activity including recent sessions and what it has been working on.",
|
|
551
|
+
inputSchema: {
|
|
552
|
+
type: "object",
|
|
553
|
+
properties: {},
|
|
554
|
+
},
|
|
555
|
+
},
|
|
556
|
+
{
|
|
557
|
+
name: "delegate",
|
|
558
|
+
description: "Request the agent to handle a task. The agent queues the task and will work on it when available.",
|
|
559
|
+
inputSchema: {
|
|
560
|
+
type: "object",
|
|
561
|
+
properties: {
|
|
562
|
+
task: { type: "string", description: "Description of the task to delegate" },
|
|
563
|
+
context: { type: "string", description: "Additional context about the task" },
|
|
564
|
+
},
|
|
565
|
+
required: ["task"],
|
|
566
|
+
},
|
|
567
|
+
},
|
|
568
|
+
{
|
|
569
|
+
name: "get_context",
|
|
570
|
+
description: "Get the agent's current working context including note summary, active tasks, and relevant state.",
|
|
571
|
+
inputSchema: {
|
|
572
|
+
type: "object",
|
|
573
|
+
properties: {},
|
|
574
|
+
},
|
|
575
|
+
},
|
|
576
|
+
{
|
|
577
|
+
name: "search_notes",
|
|
578
|
+
description: "Search the agent's diary for information about a specific topic. Returns matching diary lines.",
|
|
579
|
+
inputSchema: {
|
|
580
|
+
type: "object",
|
|
581
|
+
properties: {
|
|
582
|
+
query: { type: "string", description: "Search term to look for in agent notes" },
|
|
583
|
+
},
|
|
584
|
+
required: ["query"],
|
|
585
|
+
},
|
|
586
|
+
},
|
|
587
|
+
{
|
|
588
|
+
name: "get_task",
|
|
589
|
+
description: "Get details about the agent's current task or list of active tasks.",
|
|
590
|
+
inputSchema: {
|
|
591
|
+
type: "object",
|
|
592
|
+
properties: {},
|
|
593
|
+
},
|
|
594
|
+
},
|
|
595
|
+
{
|
|
596
|
+
name: "check_scope",
|
|
597
|
+
description: "Check whether a proposed item or change is in scope for the agent's current work.",
|
|
598
|
+
inputSchema: {
|
|
599
|
+
type: "object",
|
|
600
|
+
properties: {
|
|
601
|
+
item: { type: "string", description: "The item or change to check scope for" },
|
|
602
|
+
},
|
|
603
|
+
required: ["item"],
|
|
604
|
+
},
|
|
605
|
+
},
|
|
606
|
+
{
|
|
607
|
+
name: "request_decision",
|
|
608
|
+
description: "Ask the agent to make a decision about a topic. Optionally provide a list of options to choose from.",
|
|
609
|
+
inputSchema: {
|
|
610
|
+
type: "object",
|
|
611
|
+
properties: {
|
|
612
|
+
topic: { type: "string", description: "The topic requiring a decision" },
|
|
613
|
+
options: { type: "string", description: "Comma-separated list of options to consider" },
|
|
614
|
+
},
|
|
615
|
+
required: ["topic"],
|
|
616
|
+
},
|
|
617
|
+
},
|
|
618
|
+
{
|
|
619
|
+
name: "check_guidance",
|
|
620
|
+
description: "Get guidance from the agent on how to approach a topic. The agent searches its diary, journal, and session context for relevant guidance.",
|
|
621
|
+
inputSchema: {
|
|
622
|
+
type: "object",
|
|
623
|
+
properties: {
|
|
624
|
+
topic: { type: "string", description: "The topic to get guidance on" },
|
|
625
|
+
},
|
|
626
|
+
required: ["topic"],
|
|
627
|
+
},
|
|
628
|
+
},
|
|
629
|
+
{
|
|
630
|
+
name: "report_progress",
|
|
631
|
+
description: "Report progress on delegated work back to the agent. The agent records the update.",
|
|
632
|
+
inputSchema: {
|
|
633
|
+
type: "object",
|
|
634
|
+
properties: {
|
|
635
|
+
summary: { type: "string", description: "Summary of progress made" },
|
|
636
|
+
},
|
|
637
|
+
required: ["summary"],
|
|
638
|
+
},
|
|
639
|
+
},
|
|
640
|
+
{
|
|
641
|
+
name: "report_blocker",
|
|
642
|
+
description: "Report a blocker on delegated work to the agent. The agent records the blocker for review.",
|
|
643
|
+
inputSchema: {
|
|
644
|
+
type: "object",
|
|
645
|
+
properties: {
|
|
646
|
+
blocker: { type: "string", description: "Description of the blocker" },
|
|
647
|
+
},
|
|
648
|
+
required: ["blocker"],
|
|
649
|
+
},
|
|
650
|
+
},
|
|
651
|
+
{
|
|
652
|
+
name: "report_complete",
|
|
653
|
+
description: "Report completion of delegated work to the agent. The agent records the completion.",
|
|
654
|
+
inputSchema: {
|
|
655
|
+
type: "object",
|
|
656
|
+
properties: {
|
|
657
|
+
summary: { type: "string", description: "Summary of what was completed" },
|
|
658
|
+
},
|
|
659
|
+
required: ["summary"],
|
|
660
|
+
},
|
|
661
|
+
},
|
|
662
|
+
{
|
|
663
|
+
name: "send_message",
|
|
664
|
+
description: "Send a message to the agent and get a synchronous response. This runs a full agent turn — the agent can use tools, think, and respond. For multi-turn conversations, call repeatedly — the agent keeps prior turns in this session.",
|
|
665
|
+
inputSchema: {
|
|
666
|
+
type: "object",
|
|
667
|
+
properties: {
|
|
668
|
+
message: { type: "string", description: "The message to send to the agent" },
|
|
669
|
+
},
|
|
670
|
+
required: ["message"],
|
|
671
|
+
},
|
|
672
|
+
},
|
|
673
|
+
{
|
|
674
|
+
name: "check_response",
|
|
675
|
+
description: "Check for pending messages from the agent. Use this after send_message returns a ponder deferral, or to pick up proactive messages the agent has surfaced to you.",
|
|
676
|
+
inputSchema: {
|
|
677
|
+
type: "object",
|
|
678
|
+
properties: {},
|
|
679
|
+
},
|
|
680
|
+
},
|
|
681
|
+
];
|
|
682
|
+
}
|
|
683
|
+
// MCP server v0.1.0-alpha.140
|