@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
|
@@ -36,8 +36,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
36
36
|
exports.spawnCodingProcess = spawnCodingProcess;
|
|
37
37
|
const child_process_1 = require("child_process");
|
|
38
38
|
const fs = __importStar(require("fs"));
|
|
39
|
+
const os = __importStar(require("os"));
|
|
40
|
+
const path = __importStar(require("path"));
|
|
39
41
|
const runtime_1 = require("../../nerves/runtime");
|
|
40
|
-
function buildCommandArgs(runner, workdir) {
|
|
42
|
+
function buildCommandArgs(runner, workdir, parentAgent) {
|
|
41
43
|
if (runner === "claude") {
|
|
42
44
|
return {
|
|
43
45
|
command: "claude",
|
|
@@ -53,25 +55,65 @@ function buildCommandArgs(runner, workdir) {
|
|
|
53
55
|
],
|
|
54
56
|
};
|
|
55
57
|
}
|
|
58
|
+
const agent = parentAgent ?? "unknown";
|
|
59
|
+
// Use absolute path to ouro-entry.js so MCP works in both dev and installed mode
|
|
60
|
+
// __dirname at runtime is dist/repertoire/coding/ — go up 2 levels to dist/
|
|
61
|
+
const distRoot = path.resolve(__dirname, "..", "..");
|
|
62
|
+
const ouroEntryPath = path.join(distRoot, "heart", "daemon", "ouro-entry.js");
|
|
56
63
|
return {
|
|
57
64
|
command: "codex",
|
|
58
|
-
args: [
|
|
65
|
+
args: [
|
|
66
|
+
"exec",
|
|
67
|
+
"--skip-git-repo-check",
|
|
68
|
+
"--cd",
|
|
69
|
+
workdir,
|
|
70
|
+
"--ephemeral",
|
|
71
|
+
"--json",
|
|
72
|
+
"-c",
|
|
73
|
+
`mcp_servers.ouro.command=node`,
|
|
74
|
+
"-c",
|
|
75
|
+
`mcp_servers.ouro.args=["${ouroEntryPath}","mcp-serve","--agent","${agent}"]`,
|
|
76
|
+
],
|
|
59
77
|
};
|
|
60
78
|
}
|
|
79
|
+
function buildSpawnEnv(baseEnv, homeDir) {
|
|
80
|
+
const binDir = path.join(homeDir, ".ouro-cli", "bin");
|
|
81
|
+
const existingPath = baseEnv.PATH ?? "";
|
|
82
|
+
const pathEntries = existingPath.split(path.delimiter).filter((entry) => entry.length > 0);
|
|
83
|
+
if (!pathEntries.includes(binDir)) {
|
|
84
|
+
pathEntries.unshift(binDir);
|
|
85
|
+
}
|
|
86
|
+
return {
|
|
87
|
+
...baseEnv,
|
|
88
|
+
PATH: pathEntries.join(path.delimiter),
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
function appendFileSection(sections, label, filePath, deps) {
|
|
92
|
+
if (!filePath || !deps.existsSync(filePath))
|
|
93
|
+
return;
|
|
94
|
+
const content = deps.readFileSync(filePath, "utf-8").trim();
|
|
95
|
+
if (content.length === 0)
|
|
96
|
+
return;
|
|
97
|
+
sections.push(`${label} (${filePath}):\n${content}`);
|
|
98
|
+
}
|
|
61
99
|
function buildPrompt(request, deps) {
|
|
62
100
|
const sections = [];
|
|
101
|
+
sections.push([
|
|
102
|
+
"Execution contract:",
|
|
103
|
+
"- You are a subordinate coding session launched by a parent Ouro agent.",
|
|
104
|
+
"- Execute the concrete request in the supplied workdir directly.",
|
|
105
|
+
"- Do not switch into planning/doing workflows, approval gates, or repo-management rituals unless the request explicitly asks for them.",
|
|
106
|
+
"- Treat the request, scope file, and state file as the authoritative briefing for this session.",
|
|
107
|
+
"- Prefer direct execution and verification over narration.",
|
|
108
|
+
].join("\n"));
|
|
63
109
|
sections.push([
|
|
64
110
|
"Coding session metadata:",
|
|
65
111
|
`sessionId: ${request.sessionId ?? "pending"}`,
|
|
66
112
|
`parentAgent: ${request.parentAgent ?? "unknown"}`,
|
|
67
113
|
`taskRef: ${request.taskRef ?? "unassigned"}`,
|
|
68
114
|
].join("\n"));
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
if (stateContent.length > 0) {
|
|
72
|
-
sections.push(`State file (${request.stateFile}):\n${stateContent}`);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
115
|
+
appendFileSection(sections, "Scope file", request.scopeFile, deps);
|
|
116
|
+
appendFileSection(sections, "State file", request.stateFile, deps);
|
|
75
117
|
sections.push(request.prompt);
|
|
76
118
|
return sections.join("\n\n---\n\n");
|
|
77
119
|
}
|
|
@@ -79,8 +121,11 @@ function spawnCodingProcess(request, deps = {}) {
|
|
|
79
121
|
const spawnFn = deps.spawnFn ?? ((command, args, options) => (0, child_process_1.spawn)(command, args, options));
|
|
80
122
|
const existsSync = deps.existsSync ?? fs.existsSync;
|
|
81
123
|
const readFileSync = deps.readFileSync ?? fs.readFileSync;
|
|
124
|
+
const homeDir = deps.homeDir ?? os.homedir();
|
|
125
|
+
const baseEnv = deps.baseEnv ?? process.env;
|
|
82
126
|
const prompt = buildPrompt(request, { existsSync, readFileSync });
|
|
83
|
-
const { command, args } = buildCommandArgs(request.runner, request.workdir);
|
|
127
|
+
const { command, args } = buildCommandArgs(request.runner, request.workdir, request.parentAgent);
|
|
128
|
+
const env = buildSpawnEnv(baseEnv, homeDir);
|
|
84
129
|
(0, runtime_1.emitNervesEvent)({
|
|
85
130
|
component: "repertoire",
|
|
86
131
|
event: "repertoire.coding_spawn_start",
|
|
@@ -89,6 +134,7 @@ function spawnCodingProcess(request, deps = {}) {
|
|
|
89
134
|
});
|
|
90
135
|
const proc = spawnFn(command, args, {
|
|
91
136
|
cwd: request.workdir,
|
|
137
|
+
env,
|
|
92
138
|
stdio: ["pipe", "pipe", "pipe"],
|
|
93
139
|
});
|
|
94
140
|
proc.stdin.end(`${prompt}\n`);
|
|
@@ -1,8 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.codingToolDefinitions = void 0;
|
|
4
|
+
exports.countFilesInSessionOutput = countFilesInSessionOutput;
|
|
4
5
|
const index_1 = require("./index");
|
|
6
|
+
const context_pack_1 = require("./context-pack");
|
|
7
|
+
const identity_1 = require("../../heart/identity");
|
|
8
|
+
const obligations_1 = require("../../arc/obligations");
|
|
9
|
+
const evolution_1 = require("../../arc/evolution");
|
|
5
10
|
const runtime_1 = require("../../nerves/runtime");
|
|
11
|
+
const scrutiny_1 = require("../../mind/scrutiny");
|
|
6
12
|
const RUNNERS = ["claude", "codex"];
|
|
7
13
|
function requireArg(args, key) {
|
|
8
14
|
const value = args[key];
|
|
@@ -29,11 +35,136 @@ function emitCodingToolEvent(toolName) {
|
|
|
29
35
|
meta: { toolName },
|
|
30
36
|
});
|
|
31
37
|
}
|
|
38
|
+
/**
|
|
39
|
+
* Count distinct file paths mentioned in a coding session's stdout output.
|
|
40
|
+
* Looks for path-like tokens (containing / and a file extension).
|
|
41
|
+
* Returns the count of unique paths found.
|
|
42
|
+
*/
|
|
43
|
+
function countFilesInSessionOutput(session) {
|
|
44
|
+
const text = `${session.stdoutTail}\n${session.stderrTail}`;
|
|
45
|
+
// Match path-like tokens: contain at least one / and a file extension
|
|
46
|
+
const pathPattern = /(?:^|\s)((?:\/|\.\/|\.\.\/)?(?:[\w.@-]+\/)+[\w.-]+\.[\w]+)/gm;
|
|
47
|
+
const paths = new Set();
|
|
48
|
+
let match;
|
|
49
|
+
while ((match = pathPattern.exec(text)) !== null) {
|
|
50
|
+
paths.add(match[1]);
|
|
51
|
+
}
|
|
52
|
+
return paths.size;
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* If a coding session is completed, append scrutiny to the result.
|
|
56
|
+
* Returns the original result with scrutiny appended, or unchanged if
|
|
57
|
+
* the session is not completed or has no file changes.
|
|
58
|
+
*/
|
|
59
|
+
function appendCompletionScrutiny(result, session) {
|
|
60
|
+
if (session.status !== "completed")
|
|
61
|
+
return result;
|
|
62
|
+
const fileCount = countFilesInSessionOutput(session);
|
|
63
|
+
const scrutiny = (0, scrutiny_1.getCodingCompletionScrutiny)(fileCount);
|
|
64
|
+
return scrutiny ? `${result}\n\n${scrutiny}` : result;
|
|
65
|
+
}
|
|
66
|
+
function sameOriginSession(left, right) {
|
|
67
|
+
if (!left && !right)
|
|
68
|
+
return true;
|
|
69
|
+
if (!left || !right)
|
|
70
|
+
return false;
|
|
71
|
+
return left.friendId === right.friendId && left.channel === right.channel && left.key === right.key;
|
|
72
|
+
}
|
|
73
|
+
function matchesReusableCodingSession(session, request) {
|
|
74
|
+
if (session.status !== "spawning" && session.status !== "running" && session.status !== "waiting_input" && session.status !== "stalled") {
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
const scopeMatches = request.scopeFile ? session.scopeFile === request.scopeFile : true;
|
|
78
|
+
const stateMatches = request.stateFile ? session.stateFile === request.stateFile : true;
|
|
79
|
+
const evolutionCaseMatches = request.evolutionCaseId ? session.evolutionCaseId === request.evolutionCaseId : true;
|
|
80
|
+
return (session.runner === request.runner &&
|
|
81
|
+
session.workdir === request.workdir &&
|
|
82
|
+
session.taskRef === request.taskRef &&
|
|
83
|
+
scopeMatches &&
|
|
84
|
+
stateMatches &&
|
|
85
|
+
evolutionCaseMatches &&
|
|
86
|
+
session.obligationId === request.obligationId &&
|
|
87
|
+
sameOriginSession(request.originSession, session.originSession));
|
|
88
|
+
}
|
|
89
|
+
function latestSessionFirst(left, right) {
|
|
90
|
+
const lastActivityDelta = Date.parse(right.lastActivityAt) - Date.parse(left.lastActivityAt);
|
|
91
|
+
if (lastActivityDelta !== 0)
|
|
92
|
+
return lastActivityDelta;
|
|
93
|
+
return right.id.localeCompare(left.id);
|
|
94
|
+
}
|
|
95
|
+
function findReusableCodingSession(sessions, request) {
|
|
96
|
+
const matches = sessions.filter((session) => matchesReusableCodingSession(session, request)).sort(latestSessionFirst);
|
|
97
|
+
return matches[0] ?? null;
|
|
98
|
+
}
|
|
99
|
+
function isLiveCodingStatus(status) {
|
|
100
|
+
return status === "spawning" || status === "running" || status === "waiting_input" || status === "stalled";
|
|
101
|
+
}
|
|
102
|
+
function rankCodingStatusSession(session, currentSession) {
|
|
103
|
+
return sameOriginSession({
|
|
104
|
+
friendId: currentSession.friendId,
|
|
105
|
+
channel: currentSession.channel,
|
|
106
|
+
key: currentSession.key,
|
|
107
|
+
}, session.originSession)
|
|
108
|
+
? 0
|
|
109
|
+
: 1;
|
|
110
|
+
}
|
|
111
|
+
function selectCodingStatusSessions(sessions, currentSession) {
|
|
112
|
+
if (sessions.length === 0)
|
|
113
|
+
return [];
|
|
114
|
+
if (!currentSession) {
|
|
115
|
+
return sessions;
|
|
116
|
+
}
|
|
117
|
+
const activeSessions = sessions.filter((session) => isLiveCodingStatus(session.status)).sort(latestSessionFirst);
|
|
118
|
+
if (activeSessions.length > 0) {
|
|
119
|
+
return activeSessions.sort((left, right) => {
|
|
120
|
+
const rankDelta = rankCodingStatusSession(left, currentSession) - rankCodingStatusSession(right, currentSession);
|
|
121
|
+
if (rankDelta !== 0)
|
|
122
|
+
return rankDelta;
|
|
123
|
+
return latestSessionFirst(left, right);
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
const matchingClosedSessions = sessions
|
|
127
|
+
.filter((session) => sameOriginSession({
|
|
128
|
+
friendId: currentSession.friendId,
|
|
129
|
+
channel: currentSession.channel,
|
|
130
|
+
key: currentSession.key,
|
|
131
|
+
}, session.originSession))
|
|
132
|
+
.sort(latestSessionFirst);
|
|
133
|
+
if (matchingClosedSessions.length > 0) {
|
|
134
|
+
return matchingClosedSessions;
|
|
135
|
+
}
|
|
136
|
+
return [...sessions].sort(latestSessionFirst);
|
|
137
|
+
}
|
|
138
|
+
function buildCodingObligationContent(taskRef) {
|
|
139
|
+
return `finish ${taskRef} and bring the result back`;
|
|
140
|
+
}
|
|
141
|
+
function blockedEvolutionSpawnResult(evolutionCaseId, decision) {
|
|
142
|
+
return JSON.stringify({
|
|
143
|
+
ok: false,
|
|
144
|
+
blocked: true,
|
|
145
|
+
action: "spawn_coding",
|
|
146
|
+
evolutionCaseId,
|
|
147
|
+
code: decision.code,
|
|
148
|
+
reason: decision.reason,
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
function recordBlockedEvolutionSpawn(agentRoot, evolutionCaseId, decision) {
|
|
152
|
+
if (decision.code === "case_not_found")
|
|
153
|
+
return;
|
|
154
|
+
try {
|
|
155
|
+
(0, evolution_1.consumeEvolutionBudget)(agentRoot, evolutionCaseId, "spawn_coding", {
|
|
156
|
+
reason: `coding_spawn blocked: ${decision.reason}`,
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
catch {
|
|
160
|
+
// consumeEvolutionBudget records the block before throwing.
|
|
161
|
+
}
|
|
162
|
+
}
|
|
32
163
|
const codingSpawnTool = {
|
|
33
164
|
type: "function",
|
|
34
165
|
function: {
|
|
35
166
|
name: "coding_spawn",
|
|
36
|
-
description: "
|
|
167
|
+
description: "Spawn a coding session using claude or codex with task-threaded guidance. The coding session runs as a separate process with its own context. Give it a COMPLETE, SELF-CONTAINED task description -- it cannot see this conversation, doesn't know what you've tried, doesn't understand the broader context. Include: what to do, why, what files are involved, what 'done' looks like. Never delegate understanding -- don't write 'based on the conversation, fix the bug.' Write the specific file paths, line numbers, and what to change. Include any required verification steps or tests in the task description so the coding session knows how to prove the work is done.",
|
|
37
168
|
parameters: {
|
|
38
169
|
type: "object",
|
|
39
170
|
properties: {
|
|
@@ -43,6 +174,7 @@ const codingSpawnTool = {
|
|
|
43
174
|
taskRef: { type: "string" },
|
|
44
175
|
scopeFile: { type: "string" },
|
|
45
176
|
stateFile: { type: "string" },
|
|
177
|
+
evolutionCaseId: { type: "string" },
|
|
46
178
|
},
|
|
47
179
|
required: ["runner", "workdir", "prompt", "taskRef"],
|
|
48
180
|
},
|
|
@@ -52,7 +184,7 @@ const codingStatusTool = {
|
|
|
52
184
|
type: "function",
|
|
53
185
|
function: {
|
|
54
186
|
name: "coding_status",
|
|
55
|
-
description: "
|
|
187
|
+
description: "Inspect coding sessions. Omit sessionId to list all active/known sessions with their status. Use this to check progress before asking the human for a status update.",
|
|
56
188
|
parameters: {
|
|
57
189
|
type: "object",
|
|
58
190
|
properties: {
|
|
@@ -65,7 +197,7 @@ const codingTailTool = {
|
|
|
65
197
|
type: "function",
|
|
66
198
|
function: {
|
|
67
199
|
name: "coding_tail",
|
|
68
|
-
description: "
|
|
200
|
+
description: "Show recent stdout/stderr output from a coding session. Use this to understand what the session is doing or why it might be stuck. Read the actual output before reporting status -- don't guess.",
|
|
69
201
|
parameters: {
|
|
70
202
|
type: "object",
|
|
71
203
|
properties: {
|
|
@@ -130,6 +262,20 @@ exports.codingToolDefinitions = [
|
|
|
130
262
|
prompt,
|
|
131
263
|
taskRef,
|
|
132
264
|
};
|
|
265
|
+
const evolutionCaseId = optionalArg(args, "evolutionCaseId");
|
|
266
|
+
if (evolutionCaseId)
|
|
267
|
+
request.evolutionCaseId = evolutionCaseId;
|
|
268
|
+
if (ctx?.currentSession && ctx.currentSession.channel !== "inner") {
|
|
269
|
+
request.originSession = {
|
|
270
|
+
friendId: ctx.currentSession.friendId,
|
|
271
|
+
channel: ctx.currentSession.channel,
|
|
272
|
+
key: ctx.currentSession.key,
|
|
273
|
+
};
|
|
274
|
+
const obligation = (0, obligations_1.findPendingObligationForOrigin)((0, identity_1.getAgentRoot)(), request.originSession);
|
|
275
|
+
if (obligation) {
|
|
276
|
+
request.obligationId = obligation.id;
|
|
277
|
+
}
|
|
278
|
+
}
|
|
133
279
|
const scopeFile = optionalArg(args, "scopeFile");
|
|
134
280
|
if (scopeFile)
|
|
135
281
|
request.scopeFile = scopeFile;
|
|
@@ -137,7 +283,61 @@ exports.codingToolDefinitions = [
|
|
|
137
283
|
if (stateFile)
|
|
138
284
|
request.stateFile = stateFile;
|
|
139
285
|
const manager = (0, index_1.getCodingSessionManager)();
|
|
286
|
+
const existingSessions = manager.listSessions();
|
|
287
|
+
const existingSession = findReusableCodingSession(existingSessions, request);
|
|
288
|
+
if (existingSession) {
|
|
289
|
+
(0, runtime_1.emitNervesEvent)({
|
|
290
|
+
component: "repertoire",
|
|
291
|
+
event: "repertoire.coding_session_reused",
|
|
292
|
+
message: "reused active coding session",
|
|
293
|
+
meta: { id: existingSession.id, runner: existingSession.runner, taskRef: existingSession.taskRef },
|
|
294
|
+
});
|
|
295
|
+
if (ctx?.codingFeedback) {
|
|
296
|
+
(0, index_1.attachCodingSessionFeedback)(manager, existingSession, ctx.codingFeedback);
|
|
297
|
+
}
|
|
298
|
+
return JSON.stringify({ ...existingSession, reused: true });
|
|
299
|
+
}
|
|
300
|
+
if (request.evolutionCaseId) {
|
|
301
|
+
const decision = (0, evolution_1.evaluateEvolutionAction)((0, identity_1.getAgentRoot)(), request.evolutionCaseId, "spawn_coding");
|
|
302
|
+
if (!decision.allowed) {
|
|
303
|
+
recordBlockedEvolutionSpawn((0, identity_1.getAgentRoot)(), request.evolutionCaseId, decision);
|
|
304
|
+
return blockedEvolutionSpawnResult(request.evolutionCaseId, decision);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
if (request.originSession && !request.obligationId) {
|
|
308
|
+
const created = (0, obligations_1.createObligation)((0, identity_1.getAgentRoot)(), {
|
|
309
|
+
origin: request.originSession,
|
|
310
|
+
content: buildCodingObligationContent(taskRef),
|
|
311
|
+
});
|
|
312
|
+
request.obligationId = created.id;
|
|
313
|
+
}
|
|
314
|
+
if (!request.scopeFile || !request.stateFile) {
|
|
315
|
+
const generated = (0, context_pack_1.prepareCodingContextPack)({
|
|
316
|
+
request: { ...request },
|
|
317
|
+
existingSessions,
|
|
318
|
+
activeWorkFrame: ctx?.activeWorkFrame,
|
|
319
|
+
});
|
|
320
|
+
if (!request.scopeFile)
|
|
321
|
+
request.scopeFile = generated.scopeFile;
|
|
322
|
+
if (!request.stateFile)
|
|
323
|
+
request.stateFile = generated.stateFile;
|
|
324
|
+
}
|
|
140
325
|
const session = await manager.spawnSession(request);
|
|
326
|
+
if (request.evolutionCaseId) {
|
|
327
|
+
(0, evolution_1.consumeEvolutionBudget)((0, identity_1.getAgentRoot)(), request.evolutionCaseId, "spawn_coding", {
|
|
328
|
+
target: session.id,
|
|
329
|
+
reason: `coding session ${session.id} spawned`,
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
if (session.obligationId) {
|
|
333
|
+
(0, obligations_1.advanceObligation)((0, identity_1.getAgentRoot)(), session.obligationId, {
|
|
334
|
+
status: "investigating",
|
|
335
|
+
currentSurface: { kind: "coding", label: `${session.runner} ${session.id}` },
|
|
336
|
+
latestNote: session.originSession
|
|
337
|
+
? `coding session started for ${session.originSession.channel}/${session.originSession.key}`
|
|
338
|
+
: "coding session started",
|
|
339
|
+
});
|
|
340
|
+
}
|
|
141
341
|
if (args.runner === "codex" && args.taskRef) {
|
|
142
342
|
(0, runtime_1.emitNervesEvent)({
|
|
143
343
|
component: "repertoire",
|
|
@@ -151,21 +351,28 @@ exports.codingToolDefinitions = [
|
|
|
151
351
|
}
|
|
152
352
|
return JSON.stringify(session);
|
|
153
353
|
},
|
|
354
|
+
summaryKeys: ["runner", "workdir", "taskRef"],
|
|
355
|
+
riskProfile: {
|
|
356
|
+
mutates: ["durable_state_write", "external_side_effect"],
|
|
357
|
+
risk: "high",
|
|
358
|
+
reason: "spawns a separate coding process and may create obligations",
|
|
359
|
+
},
|
|
154
360
|
},
|
|
155
361
|
{
|
|
156
362
|
tool: codingStatusTool,
|
|
157
|
-
handler: (args) => {
|
|
363
|
+
handler: (args, ctx) => {
|
|
158
364
|
emitCodingToolEvent("coding_status");
|
|
159
365
|
const manager = (0, index_1.getCodingSessionManager)();
|
|
160
366
|
const sessionId = requireArg(args, "sessionId");
|
|
161
367
|
if (!sessionId) {
|
|
162
|
-
return JSON.stringify(manager.listSessions());
|
|
368
|
+
return JSON.stringify(selectCodingStatusSessions(manager.listSessions(), ctx?.currentSession));
|
|
163
369
|
}
|
|
164
370
|
const session = manager.getSession(sessionId);
|
|
165
371
|
if (!session)
|
|
166
372
|
return `session not found: ${sessionId}`;
|
|
167
|
-
return JSON.stringify(session);
|
|
373
|
+
return appendCompletionScrutiny(JSON.stringify(session), session);
|
|
168
374
|
},
|
|
375
|
+
summaryKeys: ["sessionId"],
|
|
169
376
|
},
|
|
170
377
|
{
|
|
171
378
|
tool: codingTailTool,
|
|
@@ -177,8 +384,9 @@ exports.codingToolDefinitions = [
|
|
|
177
384
|
const session = (0, index_1.getCodingSessionManager)().getSession(sessionId);
|
|
178
385
|
if (!session)
|
|
179
386
|
return `session not found: ${sessionId}`;
|
|
180
|
-
return (0, index_1.formatCodingTail)(session);
|
|
387
|
+
return appendCompletionScrutiny((0, index_1.formatCodingTail)(session), session);
|
|
181
388
|
},
|
|
389
|
+
summaryKeys: ["sessionId"],
|
|
182
390
|
},
|
|
183
391
|
{
|
|
184
392
|
tool: codingSendInputTool,
|
|
@@ -192,6 +400,8 @@ exports.codingToolDefinitions = [
|
|
|
192
400
|
return "input is required";
|
|
193
401
|
return JSON.stringify((0, index_1.getCodingSessionManager)().sendInput(sessionId, input));
|
|
194
402
|
},
|
|
403
|
+
summaryKeys: ["sessionId", "input"],
|
|
404
|
+
riskProfile: { mutates: "external_side_effect", risk: "high", reason: "sends input to a live coding process" },
|
|
195
405
|
},
|
|
196
406
|
{
|
|
197
407
|
tool: codingKillTool,
|
|
@@ -202,5 +412,7 @@ exports.codingToolDefinitions = [
|
|
|
202
412
|
return "sessionId is required";
|
|
203
413
|
return JSON.stringify((0, index_1.getCodingSessionManager)().killSession(sessionId));
|
|
204
414
|
},
|
|
415
|
+
summaryKeys: ["sessionId"],
|
|
416
|
+
riskProfile: { mutates: "external_side_effect", risk: "high", reason: "terminates a live coding process" },
|
|
205
417
|
},
|
|
206
418
|
];
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Commerce-specific error types and helpers.
|
|
4
|
+
*
|
|
5
|
+
* These errors carry structured `code` and `meta` fields for nerves event
|
|
6
|
+
* compatibility and provide patterns for common commerce failure modes:
|
|
7
|
+
* retry, price change detection, and partial failure reporting.
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.ProfileError = exports.BookingError = exports.PaymentError = exports.CommerceError = void 0;
|
|
11
|
+
exports.retryOnce = retryOnce;
|
|
12
|
+
exports.priceChangeGuard = priceChangeGuard;
|
|
13
|
+
exports.partialFailureReport = partialFailureReport;
|
|
14
|
+
// ---------------------------------------------------------------------------
|
|
15
|
+
// Error types
|
|
16
|
+
// ---------------------------------------------------------------------------
|
|
17
|
+
class CommerceError extends Error {
|
|
18
|
+
code;
|
|
19
|
+
meta;
|
|
20
|
+
constructor(message, code, meta = {}) {
|
|
21
|
+
super(message);
|
|
22
|
+
this.name = "CommerceError";
|
|
23
|
+
this.code = code;
|
|
24
|
+
this.meta = meta;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
exports.CommerceError = CommerceError;
|
|
28
|
+
class PaymentError extends CommerceError {
|
|
29
|
+
constructor(message, code, meta = {}) {
|
|
30
|
+
super(message, code, meta);
|
|
31
|
+
this.name = "PaymentError";
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.PaymentError = PaymentError;
|
|
35
|
+
class BookingError extends CommerceError {
|
|
36
|
+
constructor(message, code, meta = {}) {
|
|
37
|
+
super(message, code, meta);
|
|
38
|
+
this.name = "BookingError";
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.BookingError = BookingError;
|
|
42
|
+
class ProfileError extends CommerceError {
|
|
43
|
+
constructor(message, code, meta = {}) {
|
|
44
|
+
super(message, code, meta);
|
|
45
|
+
this.name = "ProfileError";
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
exports.ProfileError = ProfileError;
|
|
49
|
+
// ---------------------------------------------------------------------------
|
|
50
|
+
// Transient error detection
|
|
51
|
+
// ---------------------------------------------------------------------------
|
|
52
|
+
const TRANSIENT_CODES = new Set(["COMMERCE_TRANSIENT", "COMMERCE_TIMEOUT", "COMMERCE_NETWORK"]);
|
|
53
|
+
function isTransient(err) {
|
|
54
|
+
return err instanceof CommerceError && TRANSIENT_CODES.has(err.code);
|
|
55
|
+
}
|
|
56
|
+
// ---------------------------------------------------------------------------
|
|
57
|
+
// Helpers
|
|
58
|
+
// ---------------------------------------------------------------------------
|
|
59
|
+
/**
|
|
60
|
+
* Retry a function once on transient failure, then throw.
|
|
61
|
+
* Non-transient errors are thrown immediately without retry.
|
|
62
|
+
*/
|
|
63
|
+
async function retryOnce(fn) {
|
|
64
|
+
try {
|
|
65
|
+
return await fn();
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
if (!isTransient(err))
|
|
69
|
+
throw err;
|
|
70
|
+
// One retry
|
|
71
|
+
return fn();
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Throw PaymentError if the actual price differs from the approved price
|
|
76
|
+
* by more than 5%. Used to protect against price changes between search
|
|
77
|
+
* and booking.
|
|
78
|
+
*/
|
|
79
|
+
function priceChangeGuard(approved, actual) {
|
|
80
|
+
if (approved === 0 && actual === 0)
|
|
81
|
+
return;
|
|
82
|
+
if (approved === 0) {
|
|
83
|
+
throw new PaymentError(`price changed from $0 to $${actual} — cannot verify percentage change`, "PAYMENT_PRICE_CHANGED", { approved, actual });
|
|
84
|
+
}
|
|
85
|
+
const delta = Math.abs(actual - approved) / approved;
|
|
86
|
+
if (delta > 0.05) {
|
|
87
|
+
throw new PaymentError(`price changed by ${(delta * 100).toFixed(1)}% (approved: $${approved}, actual: $${actual})`, "PAYMENT_PRICE_CHANGED", { approved, actual, deltaPercent: delta * 100 });
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Format a human-readable status report for multi-service booking attempts.
|
|
92
|
+
* Each entry has a service name, status, and optional error message.
|
|
93
|
+
*/
|
|
94
|
+
function partialFailureReport(results) {
|
|
95
|
+
if (results.length === 0) {
|
|
96
|
+
return "no services attempted.";
|
|
97
|
+
}
|
|
98
|
+
const lines = results.map((r) => {
|
|
99
|
+
const status = r.status === "success" ? "success" : "failed";
|
|
100
|
+
const detail = r.error ? ` — ${r.error}` : "";
|
|
101
|
+
return ` ${r.service}: ${status}${detail}`;
|
|
102
|
+
});
|
|
103
|
+
const succeeded = results.filter((r) => r.status === "success").length;
|
|
104
|
+
const failed = results.length - succeeded;
|
|
105
|
+
return [
|
|
106
|
+
`booking status: ${succeeded} succeeded, ${failed} failed`,
|
|
107
|
+
...lines,
|
|
108
|
+
].join("\n");
|
|
109
|
+
}
|