@ouro.bot/cli 0.1.0-alpha.66 → 0.1.0-alpha.660
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 +4209 -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 +67 -4
- package/dist/mind/friends/store-file.js +61 -4
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/{associative-recall.js → note-search.js} +47 -58
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +6 -1
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1015 -140
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/record-paths.js +312 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/nerves/cli-logging.js +7 -1
- package/dist/nerves/coverage/audit-rules.js +15 -6
- package/dist/nerves/coverage/audit.js +28 -2
- package/dist/nerves/coverage/cli.js +1 -1
- package/dist/nerves/coverage/contract.js +5 -5
- package/dist/nerves/coverage/file-completeness.js +139 -5
- package/dist/nerves/event-buffer.js +111 -0
- package/dist/nerves/index.js +224 -4
- package/dist/nerves/observation.js +20 -0
- package/dist/nerves/redact.js +79 -0
- package/dist/nerves/review/cli-main.js +5 -0
- package/dist/nerves/review/cli.js +156 -0
- package/dist/nerves/review/core.js +152 -0
- package/dist/nerves/runtime.js +5 -1
- package/dist/repertoire/ado-client.js +15 -56
- package/dist/repertoire/ado-semantic.js +16 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +1041 -0
- package/dist/repertoire/bundle-templates.js +71 -0
- package/dist/repertoire/bw-installer.js +180 -0
- package/dist/repertoire/coding/codex-jsonl.js +64 -0
- package/dist/repertoire/coding/context-pack.js +331 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +166 -10
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +219 -7
- package/dist/repertoire/commerce-errors.js +109 -0
- package/dist/repertoire/commerce-self-test.js +156 -0
- package/dist/repertoire/credential-access.js +178 -0
- package/dist/repertoire/desk/classifier.js +362 -0
- package/dist/repertoire/duffel-client.js +185 -0
- package/dist/repertoire/github-client.js +14 -55
- package/dist/repertoire/graph-client.js +11 -52
- package/dist/repertoire/guardrails.js +159 -25
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +434 -0
- package/dist/repertoire/mcp-tools.js +83 -0
- package/dist/repertoire/plugin-mcp.js +175 -0
- package/dist/repertoire/plugins.js +253 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +48 -4
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-a2a.js +283 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-awaiting.js +372 -0
- package/dist/repertoire/tools-base.js +63 -1082
- package/dist/repertoire/tools-bluebubbles.js +2 -0
- package/dist/repertoire/tools-bridge.js +144 -0
- package/dist/repertoire/tools-bundle.js +993 -0
- package/dist/repertoire/tools-commerce.js +253 -0
- package/dist/repertoire/tools-config.js +186 -0
- package/dist/repertoire/tools-continuity.js +252 -0
- package/dist/repertoire/tools-credential.js +383 -0
- package/dist/repertoire/tools-evolution.js +527 -0
- package/dist/repertoire/tools-files.js +344 -0
- package/dist/repertoire/tools-flight.js +290 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +3 -8
- package/dist/repertoire/tools-mail.js +1975 -0
- package/dist/repertoire/tools-notes.js +418 -0
- package/dist/repertoire/tools-obligations.js +143 -0
- package/dist/repertoire/tools-orientation.js +31 -0
- package/dist/repertoire/tools-record.js +469 -0
- package/dist/repertoire/tools-runtime.js +150 -0
- package/dist/repertoire/tools-session.js +766 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +224 -0
- package/dist/repertoire/tools-surface.js +344 -0
- package/dist/repertoire/tools-teams.js +12 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +982 -0
- package/dist/repertoire/tools-user-profile.js +146 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools-voice.js +145 -0
- package/dist/repertoire/tools.js +243 -79
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +131 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +594 -0
- package/dist/scripts/claude-code-hook.js +41 -0
- package/dist/scripts/claude-code-stop-hook.js +47 -0
- package/dist/senses/a2a-entry.js +78 -0
- package/dist/senses/attention-queue.js +186 -0
- package/dist/senses/await-turn-message.js +58 -0
- package/dist/senses/bluebubbles/active-turns.js +216 -0
- package/dist/senses/bluebubbles/attachment-cache.js +53 -0
- package/dist/senses/bluebubbles/attachment-download.js +137 -0
- package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
- package/dist/senses/bluebubbles/entry.js +77 -0
- package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
- package/dist/senses/bluebubbles/index.js +2737 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -71
- package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
- package/dist/senses/bluebubbles/processed-log.js +133 -0
- package/dist/senses/bluebubbles/replay.js +137 -0
- package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
- package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
- package/dist/senses/bluebubbles-meta-guard.js +40 -0
- package/dist/senses/cli/bracketed-paste.js +82 -0
- package/dist/senses/cli/image-paste.js +287 -0
- package/dist/senses/cli/image-ref-navigation.js +75 -0
- package/dist/senses/cli/ink-app.js +156 -0
- package/dist/senses/cli/inline-diff.js +64 -0
- package/dist/senses/cli/input-keys.js +174 -0
- package/dist/senses/cli/kill-ring.js +86 -0
- package/dist/senses/cli/message-list.js +51 -0
- package/dist/senses/cli/ouro-tui.js +607 -0
- package/dist/senses/cli/spinner-imperative.js +135 -0
- package/dist/senses/cli/spinner.js +101 -0
- package/dist/senses/cli/status-line.js +60 -0
- package/dist/senses/cli/streaming-markdown.js +526 -0
- package/dist/senses/cli/tool-display.js +85 -0
- package/dist/senses/cli/tool-render.js +85 -0
- package/dist/senses/cli/tui-store.js +240 -0
- package/dist/senses/cli/virtual-list.js +35 -0
- package/dist/senses/cli-entry.js +60 -8
- package/dist/senses/cli-layout.js +100 -0
- package/dist/senses/cli.js +517 -204
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +122 -0
- package/dist/senses/inner-dialog-worker.js +303 -22
- package/dist/senses/inner-dialog.js +525 -41
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +857 -180
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +419 -0
- package/dist/senses/surface-tool.js +108 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +390 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/senses/voice/audio-playback.js +237 -0
- package/dist/senses/voice/audio-routing.js +119 -0
- package/dist/senses/voice/elevenlabs.js +202 -0
- package/dist/senses/voice/floor-control.js +431 -0
- package/dist/senses/voice/floor-controller.js +115 -0
- package/dist/senses/voice/golden-path.js +116 -0
- package/dist/senses/voice/index.js +29 -0
- package/dist/senses/voice/meeting.js +113 -0
- package/dist/senses/voice/outbound.js +190 -0
- package/dist/senses/voice/phone.js +33 -0
- package/dist/senses/voice/playback.js +139 -0
- package/dist/senses/voice/realtime-eval.js +496 -0
- package/dist/senses/voice/realtime-trace.js +531 -0
- package/dist/senses/voice/transcript.js +70 -0
- package/dist/senses/voice/turn.js +191 -0
- package/dist/senses/voice/twilio-phone-runtime.js +807 -0
- package/dist/senses/voice/twilio-phone.js +5079 -0
- package/dist/senses/voice/types.js +2 -0
- package/dist/senses/voice/whisper.js +161 -0
- package/dist/senses/voice-entry.js +81 -0
- package/dist/senses/voice-realtime-eval-command.js +99 -0
- package/dist/senses/voice-realtime-eval-entry.js +21 -0
- package/dist/senses/voice-twilio-entry.js +87 -0
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +265 -0
- package/dist/util/frontmatter.js +69 -0
- package/package.json +55 -12
- package/skills/agent-commerce.md +113 -0
- package/skills/browser-navigation.md +117 -0
- package/skills/commerce-setup-guide.md +116 -0
- package/skills/commerce-setup.md +84 -0
- package/skills/configure-dev-tools.md +99 -0
- package/skills/travel-planning.md +138 -0
- package/dist/heart/daemon/auth-flow.js +0 -351
- package/dist/heart/daemon/ouro-path-installer.js +0 -178
- package/dist/heart/daemon/update-hooks.js +0 -138
- package/dist/heart/safe-workspace.js +0 -228
- package/dist/heart/session-recall.js +0 -116
- package/dist/repertoire/tasks/board.js +0 -134
- package/dist/repertoire/tasks/index.js +0 -224
- package/dist/repertoire/tasks/lifecycle.js +0 -80
- package/dist/repertoire/tasks/middleware.js +0 -65
- package/dist/repertoire/tasks/parser.js +0 -173
- package/dist/repertoire/tasks/scanner.js +0 -132
- package/dist/repertoire/tasks/transitions.js +0 -144
- package/dist/senses/bluebubbles-entry.js +0 -13
- package/dist/senses/bluebubbles.js +0 -1177
- package/dist/senses/debug-activity.js +0 -148
- package/subagents/README.md +0 -7
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
- /package/dist/{repertoire/tasks/types.js → heart/attachments/sources/adapter.js} +0 -0
- /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
- /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
- /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
- /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
package/dist/heart/identity.js
CHANGED
|
@@ -33,7 +33,12 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.HARNESS_CANONICAL_REPO_URL = exports.DEFAULT_AGENT_SENSES = exports.DEFAULT_AGENT_PHRASES = exports.DEFAULT_AGENT_CONTEXT = void 0;
|
|
36
|
+
exports.HARNESS_CANONICAL_REPO_URL = exports.DEFAULT_AGENT_SENSES = exports.LEGACY_VAULT_SERVER_URL_ALIASES = exports.DEFAULT_VAULT_SERVER_URL = exports.DEFAULT_AGENT_PHRASES = exports.DEFAULT_AGENT_CONTEXT = exports.PROVIDER_CREDENTIALS = void 0;
|
|
37
|
+
exports.normalizeVaultServerUrl = normalizeVaultServerUrl;
|
|
38
|
+
exports.getVaultServerUrlCandidates = getVaultServerUrlCandidates;
|
|
39
|
+
exports.defaultStableVaultEmail = defaultStableVaultEmail;
|
|
40
|
+
exports.resolveVaultConfig = resolveVaultConfig;
|
|
41
|
+
exports.normalizeSenses = normalizeSenses;
|
|
37
42
|
exports.buildDefaultAgentTemplate = buildDefaultAgentTemplate;
|
|
38
43
|
exports.getAgentName = getAgentName;
|
|
39
44
|
exports.getRepoRoot = getRepoRoot;
|
|
@@ -45,8 +50,8 @@ exports.getAgentDaemonStateRoot = getAgentDaemonStateRoot;
|
|
|
45
50
|
exports.getAgentDaemonLogsDir = getAgentDaemonLogsDir;
|
|
46
51
|
exports.getAgentDaemonLoggingConfigPath = getAgentDaemonLoggingConfigPath;
|
|
47
52
|
exports.getAgentMessagesRoot = getAgentMessagesRoot;
|
|
53
|
+
exports.getAgentMailroomRoot = getAgentMailroomRoot;
|
|
48
54
|
exports.getAgentToolsRoot = getAgentToolsRoot;
|
|
49
|
-
exports.getAgentSecretsPath = getAgentSecretsPath;
|
|
50
55
|
exports.loadAgentConfig = loadAgentConfig;
|
|
51
56
|
exports.setAgentName = setAgentName;
|
|
52
57
|
exports.setAgentConfigOverride = setAgentConfigOverride;
|
|
@@ -56,6 +61,15 @@ const fs = __importStar(require("fs"));
|
|
|
56
61
|
const os = __importStar(require("os"));
|
|
57
62
|
const path = __importStar(require("path"));
|
|
58
63
|
const runtime_1 = require("../nerves/runtime");
|
|
64
|
+
const migrate_config_1 = require("./migrate-config");
|
|
65
|
+
/** Single source of truth for per-provider credential field names, env var mappings, and prompt labels. */
|
|
66
|
+
exports.PROVIDER_CREDENTIALS = {
|
|
67
|
+
anthropic: { required: ["setupToken"], envVars: { ANTHROPIC_API_KEY: "setupToken" }, promptLabels: { setupToken: "Anthropic setup-token" } },
|
|
68
|
+
"openai-codex": { required: ["oauthAccessToken"], envVars: { OPENAI_API_KEY: "oauthAccessToken" }, promptLabels: { oauthAccessToken: "OpenAI Codex OAuth token" } },
|
|
69
|
+
azure: { required: ["apiKey", "endpoint", "deployment"], envVars: { AZURE_OPENAI_API_KEY: "apiKey", AZURE_OPENAI_KEY: "apiKey", AZURE_OPENAI_ENDPOINT: "endpoint", AZURE_OPENAI_DEPLOYMENT: "deployment" }, promptLabels: { apiKey: "Azure API key", endpoint: "Azure endpoint", deployment: "Azure deployment" } },
|
|
70
|
+
minimax: { required: ["apiKey"], envVars: { MINIMAX_API_KEY: "apiKey" }, promptLabels: { apiKey: "MiniMax API key" } },
|
|
71
|
+
"github-copilot": { required: ["githubToken", "baseUrl"], envVars: { GH_TOKEN: "githubToken", GITHUB_TOKEN: "githubToken" }, promptLabels: { githubToken: "GitHub token" } },
|
|
72
|
+
};
|
|
59
73
|
exports.DEFAULT_AGENT_CONTEXT = {
|
|
60
74
|
maxTokens: 80000,
|
|
61
75
|
contextMargin: 20,
|
|
@@ -65,16 +79,76 @@ exports.DEFAULT_AGENT_PHRASES = {
|
|
|
65
79
|
tool: ["running tool"],
|
|
66
80
|
followup: ["processing"],
|
|
67
81
|
};
|
|
82
|
+
exports.DEFAULT_VAULT_SERVER_URL = "https://vault.ouro.bot";
|
|
83
|
+
exports.LEGACY_VAULT_SERVER_URL_ALIASES = [
|
|
84
|
+
"https://vault.ouroboros.bot",
|
|
85
|
+
"https://ouro-vault.gentleflower-74452a1e.eastus2.azurecontainerapps.io",
|
|
86
|
+
];
|
|
87
|
+
function normalizeVaultServerUrl(serverUrl) {
|
|
88
|
+
const trimmed = serverUrl.trim();
|
|
89
|
+
const withoutTrailingSlash = trimmed.replace(/\/+$/, "");
|
|
90
|
+
if (!withoutTrailingSlash) {
|
|
91
|
+
return exports.DEFAULT_VAULT_SERVER_URL;
|
|
92
|
+
}
|
|
93
|
+
if (exports.LEGACY_VAULT_SERVER_URL_ALIASES.includes(withoutTrailingSlash)) {
|
|
94
|
+
return exports.DEFAULT_VAULT_SERVER_URL;
|
|
95
|
+
}
|
|
96
|
+
return withoutTrailingSlash;
|
|
97
|
+
}
|
|
98
|
+
function getVaultServerUrlCandidates(serverUrl) {
|
|
99
|
+
const raw = serverUrl.trim();
|
|
100
|
+
const withoutTrailingSlash = raw.replace(/\/+$/, "");
|
|
101
|
+
const normalized = normalizeVaultServerUrl(serverUrl);
|
|
102
|
+
const candidates = [normalized];
|
|
103
|
+
for (const candidate of [withoutTrailingSlash, raw]) {
|
|
104
|
+
if (candidate && !candidates.includes(candidate)) {
|
|
105
|
+
candidates.push(candidate);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
if (normalized === exports.DEFAULT_VAULT_SERVER_URL) {
|
|
109
|
+
for (const alias of exports.LEGACY_VAULT_SERVER_URL_ALIASES) {
|
|
110
|
+
if (!candidates.includes(alias)) {
|
|
111
|
+
candidates.push(alias);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
return candidates;
|
|
116
|
+
}
|
|
117
|
+
function defaultStableVaultEmail(agentName) {
|
|
118
|
+
const local = agentName
|
|
119
|
+
.toLowerCase()
|
|
120
|
+
.replace(/[^a-z0-9._-]+/g, "-")
|
|
121
|
+
.replace(/^-+|-+$/g, "") || "agent";
|
|
122
|
+
return `${local}@ouro.bot`;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Resolve the vault config for an agent, applying defaults.
|
|
126
|
+
* If vault is not configured in agent.json, returns default values.
|
|
127
|
+
*/
|
|
128
|
+
function resolveVaultConfig(agentName, config) {
|
|
129
|
+
return {
|
|
130
|
+
email: config?.email ?? defaultStableVaultEmail(agentName),
|
|
131
|
+
serverUrl: normalizeVaultServerUrl(config?.serverUrl ?? exports.DEFAULT_VAULT_SERVER_URL),
|
|
132
|
+
};
|
|
133
|
+
}
|
|
68
134
|
exports.DEFAULT_AGENT_SENSES = {
|
|
69
135
|
cli: { enabled: true },
|
|
70
136
|
teams: { enabled: false },
|
|
71
137
|
bluebubbles: { enabled: false },
|
|
138
|
+
mail: { enabled: false },
|
|
139
|
+
voice: { enabled: false },
|
|
140
|
+
a2a: { enabled: false },
|
|
141
|
+
workbench: { enabled: false },
|
|
72
142
|
};
|
|
73
143
|
function normalizeSenses(value, configFile) {
|
|
74
144
|
const defaults = {
|
|
75
145
|
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
76
146
|
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
77
147
|
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
148
|
+
mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
|
|
149
|
+
voice: { ...exports.DEFAULT_AGENT_SENSES.voice },
|
|
150
|
+
a2a: { ...exports.DEFAULT_AGENT_SENSES.a2a },
|
|
151
|
+
workbench: { ...exports.DEFAULT_AGENT_SENSES.workbench },
|
|
78
152
|
};
|
|
79
153
|
if (value === undefined) {
|
|
80
154
|
return defaults;
|
|
@@ -90,7 +164,7 @@ function normalizeSenses(value, configFile) {
|
|
|
90
164
|
throw new Error(`agent.json at ${configFile} must include senses as an object when present.`);
|
|
91
165
|
}
|
|
92
166
|
const raw = value;
|
|
93
|
-
const senseNames = ["cli", "teams", "bluebubbles"];
|
|
167
|
+
const senseNames = ["cli", "teams", "bluebubbles", "mail", "voice", "a2a", "workbench"];
|
|
94
168
|
for (const senseName of senseNames) {
|
|
95
169
|
const rawSense = raw[senseName];
|
|
96
170
|
if (rawSense === undefined) {
|
|
@@ -123,14 +197,19 @@ function normalizeSenses(value, configFile) {
|
|
|
123
197
|
}
|
|
124
198
|
function buildDefaultAgentTemplate(_agentName) {
|
|
125
199
|
return {
|
|
126
|
-
version:
|
|
200
|
+
version: 2,
|
|
127
201
|
enabled: true,
|
|
128
|
-
provider: "anthropic",
|
|
202
|
+
humanFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
203
|
+
agentFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
129
204
|
context: { ...exports.DEFAULT_AGENT_CONTEXT },
|
|
130
205
|
senses: {
|
|
131
206
|
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
132
207
|
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
133
208
|
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
209
|
+
mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
|
|
210
|
+
voice: { ...exports.DEFAULT_AGENT_SENSES.voice },
|
|
211
|
+
a2a: { ...exports.DEFAULT_AGENT_SENSES.a2a },
|
|
212
|
+
workbench: { ...exports.DEFAULT_AGENT_SENSES.workbench },
|
|
134
213
|
},
|
|
135
214
|
phrases: {
|
|
136
215
|
thinking: [...exports.DEFAULT_AGENT_PHRASES.thinking],
|
|
@@ -148,12 +227,6 @@ let _agentConfigOverride = null;
|
|
|
148
227
|
*/
|
|
149
228
|
function getAgentName() {
|
|
150
229
|
if (_cachedAgentName) {
|
|
151
|
-
(0, runtime_1.emitNervesEvent)({
|
|
152
|
-
event: "identity.resolve",
|
|
153
|
-
component: "config/identity",
|
|
154
|
-
message: "resolved agent name from cache",
|
|
155
|
-
meta: { source: "cache" },
|
|
156
|
-
});
|
|
157
230
|
return _cachedAgentName;
|
|
158
231
|
}
|
|
159
232
|
const idx = process.argv.indexOf("--agent");
|
|
@@ -197,7 +270,7 @@ function resolveOptionalAgentName(agentName) {
|
|
|
197
270
|
return getAgentName();
|
|
198
271
|
}
|
|
199
272
|
catch {
|
|
200
|
-
return "
|
|
273
|
+
return "default";
|
|
201
274
|
}
|
|
202
275
|
}
|
|
203
276
|
/**
|
|
@@ -206,7 +279,7 @@ function resolveOptionalAgentName(agentName) {
|
|
|
206
279
|
function getAgentStateRoot(agentName) {
|
|
207
280
|
return path.join(getAgentRoot(resolveOptionalAgentName(agentName)), "state");
|
|
208
281
|
}
|
|
209
|
-
exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/
|
|
282
|
+
exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/ourostack/ouroboros.git";
|
|
210
283
|
function getAgentRepoWorkspacesRoot(agentName) {
|
|
211
284
|
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "workspaces");
|
|
212
285
|
}
|
|
@@ -222,26 +295,17 @@ function getAgentDaemonLoggingConfigPath(agentName) {
|
|
|
222
295
|
function getAgentMessagesRoot(agentName) {
|
|
223
296
|
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "messages");
|
|
224
297
|
}
|
|
298
|
+
function getAgentMailroomRoot(agentName) {
|
|
299
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "mailroom");
|
|
300
|
+
}
|
|
225
301
|
function getAgentToolsRoot(agentName) {
|
|
226
302
|
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "tools");
|
|
227
303
|
}
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
function getAgentSecretsPath(agentName = getAgentName()) {
|
|
232
|
-
return path.join(os.homedir(), ".agentsecrets", agentName, "secrets.json");
|
|
304
|
+
const VALID_PROVIDERS = ["azure", "minimax", "anthropic", "openai-codex", "github-copilot"];
|
|
305
|
+
function isValidProvider(value) {
|
|
306
|
+
return typeof value === "string" && VALID_PROVIDERS.includes(value);
|
|
233
307
|
}
|
|
234
|
-
|
|
235
|
-
* Load and parse `<agentRoot>/agent.json`.
|
|
236
|
-
* Reads the file fresh on each call unless an override is set.
|
|
237
|
-
* Throws descriptive error if file is missing or contains invalid JSON.
|
|
238
|
-
*/
|
|
239
|
-
function loadAgentConfig() {
|
|
240
|
-
if (_agentConfigOverride) {
|
|
241
|
-
return _agentConfigOverride;
|
|
242
|
-
}
|
|
243
|
-
const agentRoot = getAgentRoot();
|
|
244
|
-
const configFile = path.join(agentRoot, "agent.json");
|
|
308
|
+
function readAndParseAgentJson(configFile) {
|
|
245
309
|
let raw;
|
|
246
310
|
try {
|
|
247
311
|
raw = fs.readFileSync(configFile, "utf-8");
|
|
@@ -259,9 +323,8 @@ function loadAgentConfig() {
|
|
|
259
323
|
});
|
|
260
324
|
throw new Error(`Cannot read agent.json at ${configFile}. Does the agent directory exist?`);
|
|
261
325
|
}
|
|
262
|
-
let parsed;
|
|
263
326
|
try {
|
|
264
|
-
|
|
327
|
+
return JSON.parse(raw);
|
|
265
328
|
}
|
|
266
329
|
catch (error) {
|
|
267
330
|
(0, runtime_1.emitNervesEvent)({
|
|
@@ -276,6 +339,62 @@ function loadAgentConfig() {
|
|
|
276
339
|
});
|
|
277
340
|
throw new Error(`Invalid JSON in agent.json at ${configFile}. Check syntax.`);
|
|
278
341
|
}
|
|
342
|
+
}
|
|
343
|
+
function validateFacingConfig(parsed, facingName, configFile) {
|
|
344
|
+
const raw = parsed[facingName];
|
|
345
|
+
if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
|
|
346
|
+
(0, runtime_1.emitNervesEvent)({
|
|
347
|
+
level: "error",
|
|
348
|
+
event: "config_identity.error",
|
|
349
|
+
component: "config/identity",
|
|
350
|
+
message: `agent config missing or invalid ${facingName}`,
|
|
351
|
+
meta: { path: configFile, [facingName]: raw ?? null },
|
|
352
|
+
});
|
|
353
|
+
throw new Error(`agent.json at ${configFile} must include ${facingName} as { provider, model }.`);
|
|
354
|
+
}
|
|
355
|
+
const facing = raw;
|
|
356
|
+
if (!isValidProvider(facing.provider)) {
|
|
357
|
+
(0, runtime_1.emitNervesEvent)({
|
|
358
|
+
level: "error",
|
|
359
|
+
event: "config_identity.error",
|
|
360
|
+
component: "config/identity",
|
|
361
|
+
message: `agent config has invalid provider in ${facingName}`,
|
|
362
|
+
meta: { path: configFile, provider: facing.provider ?? null },
|
|
363
|
+
});
|
|
364
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.provider must be one of: ${VALID_PROVIDERS.join(", ")}.`);
|
|
365
|
+
}
|
|
366
|
+
if (typeof facing.model !== "string") {
|
|
367
|
+
(0, runtime_1.emitNervesEvent)({
|
|
368
|
+
level: "error",
|
|
369
|
+
event: "config_identity.error",
|
|
370
|
+
component: "config/identity",
|
|
371
|
+
message: `agent config has invalid model in ${facingName}`,
|
|
372
|
+
meta: { path: configFile, model: facing.model ?? null },
|
|
373
|
+
});
|
|
374
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.model must be a string.`);
|
|
375
|
+
}
|
|
376
|
+
return { provider: facing.provider, model: facing.model };
|
|
377
|
+
}
|
|
378
|
+
/**
|
|
379
|
+
* Load and parse `<agentRoot>/agent.json`.
|
|
380
|
+
* Reads the file fresh on each call unless an override is set.
|
|
381
|
+
* If the config is v1, auto-migrates to v2 via migrateAgentConfigV1ToV2 and re-reads.
|
|
382
|
+
* Throws descriptive error if file is missing or contains invalid JSON.
|
|
383
|
+
*/
|
|
384
|
+
function loadAgentConfig() {
|
|
385
|
+
if (_agentConfigOverride) {
|
|
386
|
+
return _agentConfigOverride;
|
|
387
|
+
}
|
|
388
|
+
const agentRoot = getAgentRoot();
|
|
389
|
+
const configFile = path.join(agentRoot, "agent.json");
|
|
390
|
+
let parsed = readAndParseAgentJson(configFile);
|
|
391
|
+
// Inline migration: v1 -> v2
|
|
392
|
+
const rawVersion = parsed.version;
|
|
393
|
+
const initialVersion = typeof rawVersion === "number" ? rawVersion : 1;
|
|
394
|
+
if (initialVersion < 2) {
|
|
395
|
+
(0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
|
|
396
|
+
parsed = readAndParseAgentJson(configFile);
|
|
397
|
+
}
|
|
279
398
|
const existingPhrases = parsed.phrases;
|
|
280
399
|
const needsFill = !existingPhrases ||
|
|
281
400
|
!existingPhrases.thinking ||
|
|
@@ -297,28 +416,11 @@ function loadAgentConfig() {
|
|
|
297
416
|
});
|
|
298
417
|
fs.writeFileSync(configFile, JSON.stringify(parsed, null, 2) + "\n", "utf-8");
|
|
299
418
|
}
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
(0, runtime_1.emitNervesEvent)({
|
|
306
|
-
level: "error",
|
|
307
|
-
event: "config_identity.error",
|
|
308
|
-
component: "config/identity",
|
|
309
|
-
message: "agent config missing or invalid provider",
|
|
310
|
-
meta: {
|
|
311
|
-
path: configFile,
|
|
312
|
-
provider: rawProvider,
|
|
313
|
-
},
|
|
314
|
-
});
|
|
315
|
-
throw new Error(`agent.json at ${configFile} must include provider: "azure", "minimax", "anthropic", or "openai-codex".`);
|
|
316
|
-
}
|
|
317
|
-
const provider = rawProvider;
|
|
318
|
-
const rawVersion = parsed.version;
|
|
319
|
-
const version = rawVersion === undefined ? 1 : rawVersion;
|
|
320
|
-
if (typeof version !== "number" ||
|
|
321
|
-
!Number.isInteger(version) ||
|
|
419
|
+
// Validate v2 facing configs
|
|
420
|
+
const humanFacing = validateFacingConfig(parsed, "humanFacing", configFile);
|
|
421
|
+
const agentFacing = validateFacingConfig(parsed, "agentFacing", configFile);
|
|
422
|
+
const version = typeof parsed.version === "number" ? parsed.version : 1;
|
|
423
|
+
if (!Number.isInteger(version) ||
|
|
322
424
|
version < 1) {
|
|
323
425
|
(0, runtime_1.emitNervesEvent)({
|
|
324
426
|
level: "error",
|
|
@@ -327,7 +429,7 @@ function loadAgentConfig() {
|
|
|
327
429
|
message: "agent config missing or invalid version",
|
|
328
430
|
meta: {
|
|
329
431
|
path: configFile,
|
|
330
|
-
version:
|
|
432
|
+
version: parsed.version,
|
|
331
433
|
},
|
|
332
434
|
});
|
|
333
435
|
throw new Error(`agent.json at ${configFile} must include version as integer >= 1.`);
|
|
@@ -347,15 +449,30 @@ function loadAgentConfig() {
|
|
|
347
449
|
});
|
|
348
450
|
throw new Error(`agent.json at ${configFile} must include enabled as boolean.`);
|
|
349
451
|
}
|
|
452
|
+
// Tolerate deprecated provider field for backward compatibility
|
|
453
|
+
const rawProvider = parsed.provider;
|
|
454
|
+
const provider = isValidProvider(rawProvider) ? rawProvider : undefined;
|
|
455
|
+
// Spread parsed first so any field present in AgentConfig is carried
|
|
456
|
+
// through by default, then explicitly override the fields that need
|
|
457
|
+
// validation or normalization. This eliminates the field-drop bug class
|
|
458
|
+
// that caused the `sync` block (and previously `shell`) to be silently
|
|
459
|
+
// omitted from the returned config. Regression-guarded by the
|
|
460
|
+
// Required<AgentConfig> contract test in identity-contract.test.ts.
|
|
350
461
|
const config = {
|
|
462
|
+
...parsed,
|
|
351
463
|
version,
|
|
352
464
|
enabled,
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
logging: parsed.logging,
|
|
465
|
+
humanFacing,
|
|
466
|
+
agentFacing,
|
|
356
467
|
senses: normalizeSenses(parsed.senses, configFile),
|
|
357
468
|
phrases: parsed.phrases,
|
|
358
469
|
};
|
|
470
|
+
if (provider !== undefined) {
|
|
471
|
+
config.provider = provider;
|
|
472
|
+
}
|
|
473
|
+
else {
|
|
474
|
+
delete config.provider;
|
|
475
|
+
}
|
|
359
476
|
(0, runtime_1.emitNervesEvent)({
|
|
360
477
|
event: "identity.resolve",
|
|
361
478
|
component: "config/identity",
|
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.gatherKeptNotesCandidates = gatherKeptNotesCandidates;
|
|
4
|
+
exports.renderKeptNotesOutcome = renderKeptNotesOutcome;
|
|
5
|
+
exports.injectKeptNotes = injectKeptNotes;
|
|
6
|
+
exports.createKeptNotesJudge = createKeptNotesJudge;
|
|
7
|
+
const diary_1 = require("../mind/diary");
|
|
8
|
+
const runtime_1 = require("../nerves/runtime");
|
|
9
|
+
const DEFAULT_TIMEOUT_MS = 2500;
|
|
10
|
+
const MAX_CANDIDATES = 8;
|
|
11
|
+
const NOOP_CALLBACKS = {
|
|
12
|
+
onModelStart() { },
|
|
13
|
+
onModelStreamStart() { },
|
|
14
|
+
onTextChunk() { },
|
|
15
|
+
onReasoningChunk() { },
|
|
16
|
+
onToolStart() { },
|
|
17
|
+
onToolEnd() { },
|
|
18
|
+
onError() { },
|
|
19
|
+
};
|
|
20
|
+
function elapsedSince(startedAt) {
|
|
21
|
+
return Math.max(0, Date.now() - startedAt);
|
|
22
|
+
}
|
|
23
|
+
function latestUserText(messages) {
|
|
24
|
+
for (let i = messages.length - 1; i >= 0; i--) {
|
|
25
|
+
const message = messages[i];
|
|
26
|
+
if (message.role !== "user" || typeof message.content !== "string")
|
|
27
|
+
continue;
|
|
28
|
+
const text = message.content.trim();
|
|
29
|
+
if (text)
|
|
30
|
+
return text;
|
|
31
|
+
}
|
|
32
|
+
return "";
|
|
33
|
+
}
|
|
34
|
+
function tokenize(text) {
|
|
35
|
+
return new Set(text
|
|
36
|
+
.toLowerCase()
|
|
37
|
+
.split(/[^a-z0-9]+/g)
|
|
38
|
+
.map((token) => token.trim())
|
|
39
|
+
.filter((token) => token.length > 2));
|
|
40
|
+
}
|
|
41
|
+
function scoreText(queryTerms, text) {
|
|
42
|
+
const textTerms = tokenize(text);
|
|
43
|
+
let matches = 0;
|
|
44
|
+
for (const term of queryTerms) {
|
|
45
|
+
if (textTerms.has(term))
|
|
46
|
+
matches += 1;
|
|
47
|
+
}
|
|
48
|
+
return matches / queryTerms.size;
|
|
49
|
+
}
|
|
50
|
+
function diaryCandidate(fact) {
|
|
51
|
+
return {
|
|
52
|
+
text: fact.text,
|
|
53
|
+
source: { kind: "diary", label: "diary", ref: fact.id },
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
function friendNoteCandidates(friend, queryTerms) {
|
|
57
|
+
if (!friend)
|
|
58
|
+
return [];
|
|
59
|
+
return Object.entries(friend.notes ?? {})
|
|
60
|
+
.map(([key, note]) => {
|
|
61
|
+
const text = `${friend.name} / ${key}: ${note.value}`;
|
|
62
|
+
return {
|
|
63
|
+
candidate: {
|
|
64
|
+
text,
|
|
65
|
+
source: { kind: "friend-note", label: `friend note: ${friend.name}`, ref: key },
|
|
66
|
+
},
|
|
67
|
+
score: scoreText(queryTerms, `${key} ${note.value}`),
|
|
68
|
+
};
|
|
69
|
+
})
|
|
70
|
+
.filter((entry) => entry.score > 0);
|
|
71
|
+
}
|
|
72
|
+
function gatherKeptNotesCandidates(query, options = {}) {
|
|
73
|
+
const queryTerms = tokenize(query);
|
|
74
|
+
if (queryTerms.size === 0)
|
|
75
|
+
return [];
|
|
76
|
+
const diaryRoot = (0, diary_1.resolveDiaryRoot)(options.diaryRoot);
|
|
77
|
+
const diaryEntries = (0, diary_1.readDiaryEntries)(diaryRoot);
|
|
78
|
+
const diaryCandidates = diaryEntries
|
|
79
|
+
.map((fact) => ({ candidate: diaryCandidate(fact), score: scoreText(queryTerms, fact.text) }))
|
|
80
|
+
.filter((entry) => entry.score > 0);
|
|
81
|
+
return [...diaryCandidates, ...friendNoteCandidates(options.friend, queryTerms)]
|
|
82
|
+
.sort((left, right) => right.score - left.score)
|
|
83
|
+
.slice(0, MAX_CANDIDATES)
|
|
84
|
+
.map((entry) => entry.candidate);
|
|
85
|
+
}
|
|
86
|
+
function selectedSources(candidates, indexes) {
|
|
87
|
+
if (!indexes || indexes.length === 0)
|
|
88
|
+
return [];
|
|
89
|
+
const sources = [];
|
|
90
|
+
for (const index of indexes) {
|
|
91
|
+
if (!Number.isInteger(index))
|
|
92
|
+
continue;
|
|
93
|
+
const candidate = candidates[index];
|
|
94
|
+
if (candidate)
|
|
95
|
+
sources.push(candidate.source);
|
|
96
|
+
}
|
|
97
|
+
return sources;
|
|
98
|
+
}
|
|
99
|
+
function isFirstPerson(text) {
|
|
100
|
+
return /^(i|i'm|i’ve|i've|my|me)\b/i.test(text.trim());
|
|
101
|
+
}
|
|
102
|
+
function foundLine(text) {
|
|
103
|
+
const trimmed = text.trim();
|
|
104
|
+
if (isFirstPerson(trimmed))
|
|
105
|
+
return trimmed;
|
|
106
|
+
return `I kept this: ${trimmed}`;
|
|
107
|
+
}
|
|
108
|
+
function fuzzyLine(text) {
|
|
109
|
+
const trimmed = text.trim();
|
|
110
|
+
if (isFirstPerson(trimmed))
|
|
111
|
+
return trimmed;
|
|
112
|
+
return `I may have kept something related: ${trimmed}`;
|
|
113
|
+
}
|
|
114
|
+
const SOURCE_KIND_ORDER = ["diary", "friend-note"];
|
|
115
|
+
const SOURCE_KIND_LABELS = {
|
|
116
|
+
diary: "my Desk record diary",
|
|
117
|
+
"friend-note": "my friend notes",
|
|
118
|
+
};
|
|
119
|
+
function joinLabels(labels) {
|
|
120
|
+
if (labels.length === 1)
|
|
121
|
+
return labels[0];
|
|
122
|
+
return `${labels[0]} and ${labels[1]}`;
|
|
123
|
+
}
|
|
124
|
+
function sourceHeading(sources) {
|
|
125
|
+
const sourceKinds = new Set(sources.map((source) => source.kind));
|
|
126
|
+
const labels = SOURCE_KIND_ORDER
|
|
127
|
+
.filter((kind) => sourceKinds.has(kind))
|
|
128
|
+
.map((kind) => SOURCE_KIND_LABELS[kind]);
|
|
129
|
+
if (labels.length === 0)
|
|
130
|
+
return "## from my kept record";
|
|
131
|
+
return `## from ${joinLabels(labels)}`;
|
|
132
|
+
}
|
|
133
|
+
function renderKeptNotesOutcome(outcome) {
|
|
134
|
+
if (outcome.status === "found") {
|
|
135
|
+
return `${sourceHeading(outcome.sources)}\nThis may matter now:\n${foundLine(outcome.note)}`;
|
|
136
|
+
}
|
|
137
|
+
if (outcome.status === "fuzzy") {
|
|
138
|
+
return `${sourceHeading(outcome.sources)}\nThis is only a possible match; I should verify it before relying on it:\n${fuzzyLine(outcome.hint)}`;
|
|
139
|
+
}
|
|
140
|
+
return null;
|
|
141
|
+
}
|
|
142
|
+
function finish(outcome, traceId) {
|
|
143
|
+
(0, runtime_1.emitNervesEvent)({
|
|
144
|
+
component: "mind",
|
|
145
|
+
event: "mind.kept_notes_end",
|
|
146
|
+
trace_id: traceId,
|
|
147
|
+
message: "kept notes completed",
|
|
148
|
+
meta: { status: outcome.status, elapsedMs: outcome.elapsedMs },
|
|
149
|
+
});
|
|
150
|
+
return outcome;
|
|
151
|
+
}
|
|
152
|
+
async function withTimeout(promise, timeoutMs) {
|
|
153
|
+
return await new Promise((resolve, reject) => {
|
|
154
|
+
const timeout = setTimeout(() => resolve("timeout"), timeoutMs);
|
|
155
|
+
promise
|
|
156
|
+
.then((value) => {
|
|
157
|
+
clearTimeout(timeout);
|
|
158
|
+
resolve(value);
|
|
159
|
+
})
|
|
160
|
+
.catch((error) => {
|
|
161
|
+
clearTimeout(timeout);
|
|
162
|
+
reject(error);
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
async function injectKeptNotes(messages, options = {}) {
|
|
167
|
+
const startedAt = Date.now();
|
|
168
|
+
const systemMessage = messages[0];
|
|
169
|
+
const query = latestUserText(messages);
|
|
170
|
+
if (systemMessage?.role !== "system" || typeof systemMessage.content !== "string" || !query) {
|
|
171
|
+
return { status: "none", elapsedMs: elapsedSince(startedAt), pressure: [] };
|
|
172
|
+
}
|
|
173
|
+
(0, runtime_1.emitNervesEvent)({
|
|
174
|
+
component: "mind",
|
|
175
|
+
event: "mind.kept_notes_start",
|
|
176
|
+
trace_id: options.traceId,
|
|
177
|
+
message: "kept notes started",
|
|
178
|
+
meta: { channel: options.channel ?? "unknown" },
|
|
179
|
+
});
|
|
180
|
+
try {
|
|
181
|
+
const candidates = gatherKeptNotesCandidates(query, options);
|
|
182
|
+
if (candidates.length === 0 || !options.judge) {
|
|
183
|
+
return finish({ status: "none", elapsedMs: elapsedSince(startedAt), pressure: [] }, options.traceId);
|
|
184
|
+
}
|
|
185
|
+
const judged = await withTimeout(options.judge({ query, candidates }), options.timeoutMs ?? DEFAULT_TIMEOUT_MS);
|
|
186
|
+
if (judged === "timeout") {
|
|
187
|
+
return finish({ status: "timeout", elapsedMs: elapsedSince(startedAt) }, options.traceId);
|
|
188
|
+
}
|
|
189
|
+
const elapsedMs = elapsedSince(startedAt);
|
|
190
|
+
const outcome = judged.status === "found"
|
|
191
|
+
? { status: "found", note: judged.note, sources: selectedSources(candidates, judged.sourceIndexes), elapsedMs }
|
|
192
|
+
: judged.status === "fuzzy"
|
|
193
|
+
? { status: "fuzzy", hint: judged.hint, sources: selectedSources(candidates, judged.sourceIndexes), elapsedMs }
|
|
194
|
+
: { status: "none", pressure: judged.pressure, elapsedMs };
|
|
195
|
+
if (outcome.status === "found" || outcome.status === "fuzzy") {
|
|
196
|
+
const rendered = renderKeptNotesOutcome(outcome);
|
|
197
|
+
messages[0] = { role: "system", content: `${systemMessage.content}\n\n${rendered}` };
|
|
198
|
+
(0, runtime_1.emitNervesEvent)({
|
|
199
|
+
component: "mind",
|
|
200
|
+
event: "mind.kept_notes_injected",
|
|
201
|
+
trace_id: options.traceId,
|
|
202
|
+
message: "kept notes injected",
|
|
203
|
+
meta: { status: outcome.status, sourceCount: outcome.sources.length },
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
return finish(outcome, options.traceId);
|
|
207
|
+
}
|
|
208
|
+
catch (error) {
|
|
209
|
+
const reason = error instanceof Error ? error.message : String(error);
|
|
210
|
+
const outcome = { status: "error", reason, elapsedMs: elapsedSince(startedAt) };
|
|
211
|
+
(0, runtime_1.emitNervesEvent)({
|
|
212
|
+
level: "warn",
|
|
213
|
+
component: "mind",
|
|
214
|
+
event: "mind.kept_notes_error",
|
|
215
|
+
trace_id: options.traceId,
|
|
216
|
+
message: "kept notes failed",
|
|
217
|
+
meta: { reason },
|
|
218
|
+
});
|
|
219
|
+
return finish(outcome, options.traceId);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
function parseJudgeResult(content) {
|
|
223
|
+
try {
|
|
224
|
+
const parsed = JSON.parse(content);
|
|
225
|
+
if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
|
|
226
|
+
return { status: "none", pressure: ["invalid kept notes judge output"] };
|
|
227
|
+
}
|
|
228
|
+
const record = parsed;
|
|
229
|
+
if (record.status === "found" && typeof record.note === "string" && record.note.trim()) {
|
|
230
|
+
return {
|
|
231
|
+
status: "found",
|
|
232
|
+
note: record.note.trim(),
|
|
233
|
+
sourceIndexes: Array.isArray(record.sourceIndexes) ? record.sourceIndexes.filter((index) => typeof index === "number") : undefined,
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
if (record.status === "fuzzy" && typeof record.hint === "string" && record.hint.trim()) {
|
|
237
|
+
return {
|
|
238
|
+
status: "fuzzy",
|
|
239
|
+
hint: record.hint.trim(),
|
|
240
|
+
sourceIndexes: Array.isArray(record.sourceIndexes) ? record.sourceIndexes.filter((index) => typeof index === "number") : undefined,
|
|
241
|
+
};
|
|
242
|
+
}
|
|
243
|
+
if (record.status === "none") {
|
|
244
|
+
return {
|
|
245
|
+
status: "none",
|
|
246
|
+
pressure: Array.isArray(record.pressure) ? record.pressure.filter((value) => typeof value === "string") : [],
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
return { status: "none", pressure: ["invalid kept notes judge output"] };
|
|
250
|
+
}
|
|
251
|
+
catch {
|
|
252
|
+
return { status: "none", pressure: ["invalid kept notes judge output"] };
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
function createJudgePrompt(input) {
|
|
256
|
+
const candidates = input.candidates
|
|
257
|
+
.map((candidate, index) => `${index}. [${candidate.source.kind}] ${candidate.text}`)
|
|
258
|
+
.join("\n");
|
|
259
|
+
return [
|
|
260
|
+
{
|
|
261
|
+
role: "system",
|
|
262
|
+
content: [
|
|
263
|
+
"Decide whether these intentionally kept notes matter to the user's current turn.",
|
|
264
|
+
"Return only JSON.",
|
|
265
|
+
"Use found when a note clearly helps, fuzzy when a note is close but uncertain, and none when nothing should be surfaced.",
|
|
266
|
+
"Shapes: {\"status\":\"found\",\"note\":\"...\",\"sourceIndexes\":[0]}, {\"status\":\"fuzzy\",\"hint\":\"...\",\"sourceIndexes\":[0]}, or {\"status\":\"none\",\"pressure\":[]}.",
|
|
267
|
+
].join("\n"),
|
|
268
|
+
},
|
|
269
|
+
{
|
|
270
|
+
role: "user",
|
|
271
|
+
content: `Current turn:\n${input.query}\n\nCandidates:\n${candidates}`,
|
|
272
|
+
},
|
|
273
|
+
];
|
|
274
|
+
}
|
|
275
|
+
function createKeptNotesJudge(runtime, signal) {
|
|
276
|
+
return async (input) => {
|
|
277
|
+
const messages = createJudgePrompt(input);
|
|
278
|
+
runtime.resetTurnState?.(messages);
|
|
279
|
+
const result = await runtime.streamTurn({
|
|
280
|
+
messages,
|
|
281
|
+
activeTools: [],
|
|
282
|
+
callbacks: NOOP_CALLBACKS,
|
|
283
|
+
signal,
|
|
284
|
+
toolChoiceRequired: false,
|
|
285
|
+
reasoningEffort: "low",
|
|
286
|
+
});
|
|
287
|
+
return parseJudgeResult(result.content ?? "");
|
|
288
|
+
};
|
|
289
|
+
}
|
package/dist/heart/kicks.js
CHANGED
|
@@ -5,7 +5,7 @@ exports.detectKick = detectKick;
|
|
|
5
5
|
const runtime_1 = require("../nerves/runtime");
|
|
6
6
|
const KICK_MESSAGES = {
|
|
7
7
|
empty: "I sent an empty message by accident — let me try again.",
|
|
8
|
-
narration: "I narrated instead of acting. Using the tool now -- if done, calling
|
|
8
|
+
narration: "I narrated instead of acting. Using the tool now -- if done, calling settle.",
|
|
9
9
|
tool_required: "tool-required is on — I need to call a tool. use /tool-required to turn it off.",
|
|
10
10
|
};
|
|
11
11
|
const TOOL_INTENT_PATTERNS = [
|