@ouro.bot/cli 0.1.0-alpha.6 → 0.1.0-alpha.600
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 +229 -183
- 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/SerpentGuide.ouro/agent.json +83 -0
- package/SerpentGuide.ouro/psyche/SOUL.md +25 -0
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +2 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
- package/assets/ouroboros.png +0 -0
- package/changelog.json +4182 -0
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +140 -0
- package/dist/arc/episodes.js +117 -0
- package/dist/arc/intentions.js +133 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +254 -0
- package/dist/arc/packets.js +193 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +65 -0
- package/dist/heart/active-work.js +989 -0
- 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/adapter.js +2 -0
- package/dist/heart/attachments/sources/bluebubbles.js +156 -0
- package/dist/heart/attachments/sources/cli-local-file.js +78 -0
- package/dist/heart/attachments/sources/index.js +16 -0
- package/dist/heart/attachments/store.js +103 -0
- package/dist/heart/attachments/types.js +93 -0
- package/dist/heart/auth/auth-flow.js +479 -0
- package/dist/heart/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 +97 -0
- package/dist/heart/awaiting/await-scheduler.js +377 -0
- package/dist/heart/background-operations.js +281 -0
- package/dist/heart/bridges/manager.js +358 -0
- package/dist/heart/bridges/state-machine.js +135 -0
- package/dist/heart/bridges/store.js +123 -0
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +142 -0
- package/dist/heart/config-registry.js +322 -0
- package/dist/heart/config.js +164 -135
- package/dist/heart/core.js +1069 -260
- package/dist/heart/cross-chat-delivery.js +131 -0
- package/dist/heart/daemon/agent-config-check.js +419 -0
- package/dist/heart/daemon/agent-discovery.js +180 -0
- package/dist/heart/daemon/agent-service.js +522 -0
- package/dist/heart/daemon/agentic-repair.js +547 -0
- package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
- package/dist/heart/daemon/boot-sync-probe.js +197 -0
- package/dist/heart/daemon/cadence.js +70 -0
- package/dist/heart/daemon/cli-defaults.js +776 -0
- package/dist/heart/daemon/cli-exec.js +7571 -0
- package/dist/heart/daemon/cli-help.js +498 -0
- package/dist/heart/daemon/cli-parse.js +1599 -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 +30 -758
- package/dist/heart/daemon/daemon-entry.js +540 -8
- 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 +287 -0
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +972 -20
- 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 +206 -0
- package/dist/heart/daemon/http-health-probe.js +80 -0
- package/dist/heart/daemon/human-command-screens.js +234 -0
- package/dist/heart/daemon/human-readiness.js +114 -0
- package/dist/heart/daemon/inner-status.js +89 -0
- package/dist/heart/daemon/interactive-repair.js +394 -0
- package/dist/heart/daemon/launchd.js +188 -0
- package/dist/heart/daemon/log-tailer.js +82 -12
- package/dist/heart/daemon/logs-prune.js +110 -0
- package/dist/heart/daemon/mcp-canary.js +297 -0
- package/dist/heart/daemon/message-router.js +17 -8
- package/dist/heart/daemon/os-cron-deps.js +135 -0
- package/dist/heart/daemon/os-cron.js +14 -12
- package/dist/heart/daemon/ouro-bot-entry.js +4 -2
- package/dist/heart/daemon/ouro-entry.js +3 -1
- package/dist/heart/daemon/process-manager.js +381 -26
- 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 +39 -0
- package/dist/heart/daemon/runtime-logging.js +67 -16
- package/dist/heart/daemon/runtime-metadata.js +191 -0
- package/dist/heart/daemon/runtime-mode.js +67 -0
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +731 -0
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +94 -0
- package/dist/heart/daemon/socket-client.js +349 -0
- package/dist/heart/daemon/stale-bundle-prune.js +96 -0
- package/dist/heart/daemon/startup-tui.js +330 -0
- package/dist/heart/daemon/task-scheduler.js +3 -25
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +524 -0
- package/dist/heart/daemon/up-progress.js +366 -0
- package/dist/heart/daemon/vault-items.js +56 -0
- package/dist/heart/delegation.js +62 -0
- package/dist/heart/habits/habit-migration.js +189 -0
- package/dist/heart/habits/habit-parser.js +140 -0
- package/dist/heart/habits/habit-runtime-state.js +100 -0
- package/dist/heart/habits/habit-scheduler.js +372 -0
- package/dist/heart/{daemon → hatch}/hatch-animation.js +10 -3
- package/dist/heart/{daemon → hatch}/hatch-flow.js +34 -136
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
- package/dist/heart/hatch/specialist-orchestrator.js +129 -0
- package/dist/heart/hatch/specialist-prompt.js +102 -0
- package/dist/heart/hatch/specialist-tools.js +306 -0
- package/dist/heart/identity.js +281 -67
- package/dist/heart/kept-notes.js +357 -0
- package/dist/heart/kicks.js +2 -20
- package/dist/heart/machine-identity.js +161 -0
- package/dist/heart/mail-import-discovery.js +353 -0
- package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
- package/dist/heart/mailbox/mailbox-http-response.js +7 -0
- package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
- package/dist/heart/mailbox/mailbox-http-static.js +103 -0
- package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
- package/dist/heart/mailbox/mailbox-http.js +99 -0
- package/dist/heart/mailbox/mailbox-read.js +31 -0
- package/dist/heart/mailbox/mailbox-types.js +27 -0
- package/dist/heart/mailbox/mailbox-view.js +195 -0
- package/dist/heart/mailbox/readers/agent-machine.js +382 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
- package/dist/heart/mailbox/readers/mail.js +367 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +651 -0
- package/dist/heart/mailbox/readers/sessions.js +232 -0
- package/dist/heart/mailbox/readers/shared.js +111 -0
- package/dist/heart/mcp/mcp-server.js +656 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +59 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/progress-story.js +42 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +267 -0
- package/dist/heart/provider-credentials.js +425 -0
- package/dist/heart/provider-failover.js +301 -0
- package/dist/heart/provider-models.js +81 -0
- package/dist/heart/provider-ping.js +262 -0
- package/dist/heart/provider-readiness-cache.js +40 -0
- package/dist/heart/provider-visibility.js +188 -0
- package/dist/heart/providers/anthropic-token.js +131 -0
- package/dist/heart/providers/anthropic.js +202 -50
- package/dist/heart/providers/azure.js +104 -13
- package/dist/heart/providers/error-classification.js +127 -0
- package/dist/heart/providers/github-copilot.js +145 -0
- package/dist/heart/providers/minimax-vlm.js +189 -0
- package/dist/heart/providers/minimax.js +29 -7
- package/dist/heart/providers/openai-codex.js +63 -39
- 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 +70 -0
- package/dist/heart/session-activity.js +190 -0
- package/dist/heart/session-events.js +1149 -0
- package/dist/heart/session-playback-cli-main.js +5 -0
- package/dist/heart/session-playback-cli.js +36 -0
- package/dist/heart/session-playback.js +231 -0
- package/dist/heart/session-stats-cli-main.js +5 -0
- package/dist/heart/session-stats.js +182 -0
- package/dist/heart/session-transcript.js +243 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +129 -34
- package/dist/heart/sync-classification.js +176 -0
- package/dist/heart/sync.js +449 -0
- package/dist/heart/target-resolution.js +127 -0
- package/dist/heart/tempo.js +93 -0
- package/dist/heart/temporal-view.js +41 -0
- package/dist/heart/timeouts.js +101 -0
- package/dist/heart/tool-activity-callbacks.js +59 -0
- package/dist/heart/tool-description.js +143 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +421 -0
- package/dist/heart/turn-coordinator.js +28 -0
- package/dist/heart/versioning/ouro-bot-global-installer.js +129 -0
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +426 -0
- package/dist/heart/{daemon → versioning}/ouro-uti.js +11 -2
- package/dist/heart/versioning/ouro-version-manager.js +295 -0
- package/dist/heart/versioning/staged-restart.js +146 -0
- package/dist/heart/versioning/update-checker.js +116 -0
- package/dist/heart/versioning/update-hooks.js +142 -0
- package/dist/heart/versioning/wrapper-publish-guard.js +86 -0
- package/dist/mailbox-ui/assets/index-B-461hes.js +61 -0
- package/dist/mailbox-ui/assets/index-BPr5vNuM.css +1 -0
- package/dist/mailbox-ui/index.html +15 -0
- package/dist/mailroom/attention.js +167 -0
- package/dist/mailroom/autonomy.js +209 -0
- package/dist/mailroom/blob-store.js +700 -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 +457 -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 +268 -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 +77 -1
- package/dist/mind/context.js +174 -94
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +84 -96
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/first-impressions.js +16 -2
- package/dist/mind/friends/channel.js +74 -0
- package/dist/mind/friends/group-context.js +144 -0
- package/dist/mind/friends/resolver.js +54 -2
- package/dist/mind/friends/store-file.js +58 -3
- package/dist/mind/friends/trust-explanation.js +74 -0
- package/dist/mind/friends/types.js +10 -2
- package/dist/mind/journal-index.js +161 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +76 -9
- package/dist/mind/phrases.js +1 -0
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1267 -130
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/mind/token-estimate.js +8 -12
- package/dist/nerves/cli-logging.js +22 -3
- package/dist/nerves/coverage/audit-rules.js +15 -6
- package/dist/nerves/coverage/audit.js +28 -2
- package/dist/nerves/coverage/cli.js +1 -1
- package/dist/nerves/coverage/contract.js +5 -5
- package/dist/nerves/coverage/file-completeness.js +129 -5
- package/dist/nerves/coverage/run-artifacts.js +1 -1
- package/dist/nerves/event-buffer.js +111 -0
- package/dist/nerves/index.js +224 -4
- package/dist/nerves/observation.js +20 -0
- package/dist/nerves/redact.js +79 -0
- package/dist/nerves/review/cli-main.js +5 -0
- package/dist/nerves/review/cli.js +156 -0
- package/dist/nerves/review/core.js +152 -0
- package/dist/nerves/runtime.js +5 -1
- package/dist/repertoire/ado-client.js +17 -56
- package/dist/repertoire/ado-semantic.js +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +997 -0
- package/dist/repertoire/bundle-templates.js +72 -0
- package/dist/repertoire/bw-installer.js +180 -0
- package/dist/repertoire/coding/codex-jsonl.js +64 -0
- package/dist/repertoire/coding/context-pack.js +330 -0
- package/dist/repertoire/coding/feedback.js +301 -0
- package/dist/repertoire/coding/index.js +4 -1
- package/dist/repertoire/coding/manager.js +220 -13
- package/dist/repertoire/coding/spawner.js +58 -12
- package/dist/repertoire/coding/tools.js +209 -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/data/ado-endpoints.json +188 -0
- package/dist/repertoire/duffel-client.js +185 -0
- package/dist/repertoire/github-client.js +14 -55
- package/dist/repertoire/graph-client.js +11 -52
- package/dist/repertoire/guardrails.js +396 -0
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +362 -0
- package/dist/repertoire/mcp-tools.js +63 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +15 -24
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tasks/board.js +43 -5
- package/dist/repertoire/tasks/fix.js +182 -0
- package/dist/repertoire/tasks/index.js +39 -13
- package/dist/repertoire/tasks/lifecycle.js +2 -2
- package/dist/repertoire/tasks/parser.js +3 -2
- package/dist/repertoire/tasks/scanner.js +194 -37
- package/dist/repertoire/tasks/transitions.js +16 -79
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-awaiting.js +360 -0
- package/dist/repertoire/tools-base.js +56 -707
- package/dist/repertoire/tools-bluebubbles.js +94 -0
- package/dist/repertoire/tools-bridge.js +142 -0
- package/dist/repertoire/tools-bundle.js +984 -0
- package/dist/repertoire/tools-config.js +185 -0
- package/dist/repertoire/tools-continuity.js +248 -0
- package/dist/repertoire/tools-credential.js +381 -0
- package/dist/repertoire/tools-files.js +342 -0
- package/dist/repertoire/tools-flight.js +224 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +1 -7
- package/dist/repertoire/tools-mail.js +1916 -0
- package/dist/repertoire/tools-notes.js +421 -0
- package/dist/repertoire/tools-obligations.js +142 -0
- package/dist/repertoire/tools-runtime.js +61 -0
- package/dist/repertoire/tools-session.js +809 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +180 -0
- package/dist/repertoire/tools-surface.js +345 -0
- package/dist/repertoire/tools-teams.js +64 -61
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +604 -0
- package/dist/repertoire/tools-user-profile.js +144 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools-voice.js +144 -0
- package/dist/repertoire/tools.js +154 -98
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +131 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +594 -0
- package/dist/scripts/claude-code-hook.js +41 -0
- package/dist/scripts/claude-code-stop-hook.js +47 -0
- package/dist/senses/attention-queue.js +116 -0
- package/dist/senses/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 +685 -0
- package/dist/senses/bluebubbles/entry.js +77 -0
- package/dist/senses/bluebubbles/inbound-log.js +126 -0
- package/dist/senses/bluebubbles/index.js +2548 -0
- package/dist/senses/bluebubbles/media.js +389 -0
- package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +45 -16
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +46 -6
- package/dist/senses/bluebubbles/processed-log.js +133 -0
- package/dist/senses/bluebubbles/replay.js +137 -0
- package/dist/senses/bluebubbles/runtime-state.js +137 -0
- package/dist/senses/bluebubbles/session-cleanup.js +72 -0
- 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 +187 -0
- package/dist/senses/cli.js +777 -264
- package/dist/senses/commands.js +66 -3
- package/dist/senses/continuity.js +94 -0
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +209 -16
- package/dist/senses/inner-dialog.js +682 -91
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +751 -0
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +392 -0
- package/dist/senses/surface-tool.js +70 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +925 -195
- package/dist/senses/trust-gate.js +207 -2
- 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 +5077 -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/package.json +52 -7
- package/skills/agent-commerce.md +106 -0
- package/skills/browser-navigation.md +117 -0
- package/skills/commerce-setup-guide.md +116 -0
- package/skills/commerce-setup.md +84 -0
- package/skills/configure-dev-tools.md +99 -0
- package/skills/travel-planning.md +138 -0
- package/AdoptionSpecialist.ouro/agent.json +0 -20
- package/AdoptionSpecialist.ouro/psyche/SOUL.md +0 -22
- package/dist/heart/daemon/specialist-orchestrator.js +0 -160
- package/dist/heart/daemon/specialist-prompt.js +0 -40
- package/dist/heart/daemon/specialist-session.js +0 -142
- package/dist/heart/daemon/specialist-tools.js +0 -128
- package/dist/heart/daemon/subagent-installer.js +0 -125
- package/dist/inner-worker-entry.js +0 -4
- package/dist/mind/associative-recall.js +0 -197
- package/dist/senses/bluebubbles-client.js +0 -279
- package/dist/senses/bluebubbles-entry.js +0 -11
- package/dist/senses/bluebubbles.js +0 -332
- package/subagents/README.md +0 -73
- package/subagents/work-doer.md +0 -233
- package/subagents/work-merger.md +0 -624
- package/subagents/work-planner.md +0 -373
- /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/nagini.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
package/dist/heart/identity.js
CHANGED
|
@@ -33,21 +33,43 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
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;
|
|
40
45
|
exports.getAgentBundlesRoot = getAgentBundlesRoot;
|
|
41
46
|
exports.getAgentRoot = getAgentRoot;
|
|
42
|
-
exports.
|
|
47
|
+
exports.getAgentStateRoot = getAgentStateRoot;
|
|
48
|
+
exports.getAgentRepoWorkspacesRoot = getAgentRepoWorkspacesRoot;
|
|
49
|
+
exports.getAgentDaemonStateRoot = getAgentDaemonStateRoot;
|
|
50
|
+
exports.getAgentDaemonLogsDir = getAgentDaemonLogsDir;
|
|
51
|
+
exports.getAgentDaemonLoggingConfigPath = getAgentDaemonLoggingConfigPath;
|
|
52
|
+
exports.getAgentMessagesRoot = getAgentMessagesRoot;
|
|
53
|
+
exports.getAgentMailroomRoot = getAgentMailroomRoot;
|
|
54
|
+
exports.getAgentToolsRoot = getAgentToolsRoot;
|
|
43
55
|
exports.loadAgentConfig = loadAgentConfig;
|
|
44
56
|
exports.setAgentName = setAgentName;
|
|
45
57
|
exports.setAgentConfigOverride = setAgentConfigOverride;
|
|
58
|
+
exports.resetAgentConfigCache = resetAgentConfigCache;
|
|
46
59
|
exports.resetIdentity = resetIdentity;
|
|
47
60
|
const fs = __importStar(require("fs"));
|
|
48
61
|
const os = __importStar(require("os"));
|
|
49
62
|
const path = __importStar(require("path"));
|
|
50
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
|
+
};
|
|
51
73
|
exports.DEFAULT_AGENT_CONTEXT = {
|
|
52
74
|
maxTokens: 80000,
|
|
53
75
|
contextMargin: 20,
|
|
@@ -57,12 +79,132 @@ exports.DEFAULT_AGENT_PHRASES = {
|
|
|
57
79
|
tool: ["running tool"],
|
|
58
80
|
followup: ["processing"],
|
|
59
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
|
+
}
|
|
134
|
+
exports.DEFAULT_AGENT_SENSES = {
|
|
135
|
+
cli: { enabled: true },
|
|
136
|
+
teams: { enabled: false },
|
|
137
|
+
bluebubbles: { enabled: false },
|
|
138
|
+
mail: { enabled: false },
|
|
139
|
+
voice: { enabled: false },
|
|
140
|
+
};
|
|
141
|
+
function normalizeSenses(value, configFile) {
|
|
142
|
+
const defaults = {
|
|
143
|
+
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
144
|
+
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
145
|
+
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
146
|
+
mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
|
|
147
|
+
voice: { ...exports.DEFAULT_AGENT_SENSES.voice },
|
|
148
|
+
};
|
|
149
|
+
if (value === undefined) {
|
|
150
|
+
return defaults;
|
|
151
|
+
}
|
|
152
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) {
|
|
153
|
+
(0, runtime_1.emitNervesEvent)({
|
|
154
|
+
level: "error",
|
|
155
|
+
event: "config_identity.error",
|
|
156
|
+
component: "config/identity",
|
|
157
|
+
message: "agent config has invalid senses block",
|
|
158
|
+
meta: { path: configFile },
|
|
159
|
+
});
|
|
160
|
+
throw new Error(`agent.json at ${configFile} must include senses as an object when present.`);
|
|
161
|
+
}
|
|
162
|
+
const raw = value;
|
|
163
|
+
const senseNames = ["cli", "teams", "bluebubbles", "mail", "voice"];
|
|
164
|
+
for (const senseName of senseNames) {
|
|
165
|
+
const rawSense = raw[senseName];
|
|
166
|
+
if (rawSense === undefined) {
|
|
167
|
+
continue;
|
|
168
|
+
}
|
|
169
|
+
if (!rawSense || typeof rawSense !== "object" || Array.isArray(rawSense)) {
|
|
170
|
+
(0, runtime_1.emitNervesEvent)({
|
|
171
|
+
level: "error",
|
|
172
|
+
event: "config_identity.error",
|
|
173
|
+
component: "config/identity",
|
|
174
|
+
message: "agent config has invalid sense config",
|
|
175
|
+
meta: { path: configFile, sense: senseName },
|
|
176
|
+
});
|
|
177
|
+
throw new Error(`agent.json at ${configFile} has invalid senses.${senseName} config.`);
|
|
178
|
+
}
|
|
179
|
+
const enabled = rawSense.enabled;
|
|
180
|
+
if (typeof enabled !== "boolean") {
|
|
181
|
+
(0, runtime_1.emitNervesEvent)({
|
|
182
|
+
level: "error",
|
|
183
|
+
event: "config_identity.error",
|
|
184
|
+
component: "config/identity",
|
|
185
|
+
message: "agent config has invalid sense enabled flag",
|
|
186
|
+
meta: { path: configFile, sense: senseName, enabled: enabled ?? null },
|
|
187
|
+
});
|
|
188
|
+
throw new Error(`agent.json at ${configFile} must include senses.${senseName}.enabled as boolean.`);
|
|
189
|
+
}
|
|
190
|
+
defaults[senseName] = { enabled };
|
|
191
|
+
}
|
|
192
|
+
return defaults;
|
|
193
|
+
}
|
|
60
194
|
function buildDefaultAgentTemplate(_agentName) {
|
|
61
195
|
return {
|
|
62
|
-
version:
|
|
196
|
+
version: 2,
|
|
63
197
|
enabled: true,
|
|
64
|
-
provider: "anthropic",
|
|
198
|
+
humanFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
199
|
+
agentFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
65
200
|
context: { ...exports.DEFAULT_AGENT_CONTEXT },
|
|
201
|
+
senses: {
|
|
202
|
+
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
203
|
+
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
204
|
+
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
205
|
+
mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
|
|
206
|
+
voice: { ...exports.DEFAULT_AGENT_SENSES.voice },
|
|
207
|
+
},
|
|
66
208
|
phrases: {
|
|
67
209
|
thinking: [...exports.DEFAULT_AGENT_PHRASES.thinking],
|
|
68
210
|
tool: [...exports.DEFAULT_AGENT_PHRASES.tool],
|
|
@@ -71,7 +213,6 @@ function buildDefaultAgentTemplate(_agentName) {
|
|
|
71
213
|
};
|
|
72
214
|
}
|
|
73
215
|
let _cachedAgentName = null;
|
|
74
|
-
let _cachedAgentConfig = null;
|
|
75
216
|
let _agentConfigOverride = null;
|
|
76
217
|
/**
|
|
77
218
|
* Parse `--agent <name>` from process.argv.
|
|
@@ -80,12 +221,6 @@ let _agentConfigOverride = null;
|
|
|
80
221
|
*/
|
|
81
222
|
function getAgentName() {
|
|
82
223
|
if (_cachedAgentName) {
|
|
83
|
-
(0, runtime_1.emitNervesEvent)({
|
|
84
|
-
event: "identity.resolve",
|
|
85
|
-
component: "config/identity",
|
|
86
|
-
message: "resolved agent name from cache",
|
|
87
|
-
meta: { source: "cache" },
|
|
88
|
-
});
|
|
89
224
|
return _cachedAgentName;
|
|
90
225
|
}
|
|
91
226
|
const idx = process.argv.indexOf("--agent");
|
|
@@ -113,40 +248,58 @@ function getRepoRoot() {
|
|
|
113
248
|
* Returns the shared bundle root directory: `~/AgentBundles/`
|
|
114
249
|
*/
|
|
115
250
|
function getAgentBundlesRoot() {
|
|
116
|
-
|
|
251
|
+
const homeBase = process.env.WEBSITE_SITE_NAME ? "/home" : os.homedir();
|
|
252
|
+
return path.join(homeBase, "AgentBundles");
|
|
117
253
|
}
|
|
118
254
|
/**
|
|
119
255
|
* Returns the agent-specific bundle directory: `~/AgentBundles/<agentName>.ouro/`
|
|
120
256
|
*/
|
|
121
|
-
function getAgentRoot() {
|
|
122
|
-
return path.join(getAgentBundlesRoot(), `${
|
|
257
|
+
function getAgentRoot(agentName = getAgentName()) {
|
|
258
|
+
return path.join(getAgentBundlesRoot(), `${agentName}.ouro`);
|
|
123
259
|
}
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
260
|
+
function resolveOptionalAgentName(agentName) {
|
|
261
|
+
if (agentName && agentName.trim().length > 0)
|
|
262
|
+
return agentName.trim();
|
|
263
|
+
try {
|
|
264
|
+
return getAgentName();
|
|
265
|
+
}
|
|
266
|
+
catch {
|
|
267
|
+
return "slugger";
|
|
268
|
+
}
|
|
129
269
|
}
|
|
130
270
|
/**
|
|
131
|
-
*
|
|
132
|
-
* Caches the result after first load.
|
|
133
|
-
* Throws descriptive error if file is missing or contains invalid JSON.
|
|
271
|
+
* Returns the bundle-local runtime state directory: `~/AgentBundles/<agentName>.ouro/state/`
|
|
134
272
|
*/
|
|
135
|
-
function
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
273
|
+
function getAgentStateRoot(agentName) {
|
|
274
|
+
return path.join(getAgentRoot(resolveOptionalAgentName(agentName)), "state");
|
|
275
|
+
}
|
|
276
|
+
exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/ouroborosbot/ouroboros.git";
|
|
277
|
+
function getAgentRepoWorkspacesRoot(agentName) {
|
|
278
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "workspaces");
|
|
279
|
+
}
|
|
280
|
+
function getAgentDaemonStateRoot(agentName) {
|
|
281
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "daemon");
|
|
282
|
+
}
|
|
283
|
+
function getAgentDaemonLogsDir(agentName) {
|
|
284
|
+
return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logs");
|
|
285
|
+
}
|
|
286
|
+
function getAgentDaemonLoggingConfigPath(agentName) {
|
|
287
|
+
return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logging.json");
|
|
288
|
+
}
|
|
289
|
+
function getAgentMessagesRoot(agentName) {
|
|
290
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "messages");
|
|
291
|
+
}
|
|
292
|
+
function getAgentMailroomRoot(agentName) {
|
|
293
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "mailroom");
|
|
294
|
+
}
|
|
295
|
+
function getAgentToolsRoot(agentName) {
|
|
296
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "tools");
|
|
297
|
+
}
|
|
298
|
+
const VALID_PROVIDERS = ["azure", "minimax", "anthropic", "openai-codex", "github-copilot"];
|
|
299
|
+
function isValidProvider(value) {
|
|
300
|
+
return typeof value === "string" && VALID_PROVIDERS.includes(value);
|
|
301
|
+
}
|
|
302
|
+
function readAndParseAgentJson(configFile) {
|
|
150
303
|
let raw;
|
|
151
304
|
try {
|
|
152
305
|
raw = fs.readFileSync(configFile, "utf-8");
|
|
@@ -164,9 +317,8 @@ function loadAgentConfig() {
|
|
|
164
317
|
});
|
|
165
318
|
throw new Error(`Cannot read agent.json at ${configFile}. Does the agent directory exist?`);
|
|
166
319
|
}
|
|
167
|
-
let parsed;
|
|
168
320
|
try {
|
|
169
|
-
|
|
321
|
+
return JSON.parse(raw);
|
|
170
322
|
}
|
|
171
323
|
catch (error) {
|
|
172
324
|
(0, runtime_1.emitNervesEvent)({
|
|
@@ -181,6 +333,62 @@ function loadAgentConfig() {
|
|
|
181
333
|
});
|
|
182
334
|
throw new Error(`Invalid JSON in agent.json at ${configFile}. Check syntax.`);
|
|
183
335
|
}
|
|
336
|
+
}
|
|
337
|
+
function validateFacingConfig(parsed, facingName, configFile) {
|
|
338
|
+
const raw = parsed[facingName];
|
|
339
|
+
if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
|
|
340
|
+
(0, runtime_1.emitNervesEvent)({
|
|
341
|
+
level: "error",
|
|
342
|
+
event: "config_identity.error",
|
|
343
|
+
component: "config/identity",
|
|
344
|
+
message: `agent config missing or invalid ${facingName}`,
|
|
345
|
+
meta: { path: configFile, [facingName]: raw ?? null },
|
|
346
|
+
});
|
|
347
|
+
throw new Error(`agent.json at ${configFile} must include ${facingName} as { provider, model }.`);
|
|
348
|
+
}
|
|
349
|
+
const facing = raw;
|
|
350
|
+
if (!isValidProvider(facing.provider)) {
|
|
351
|
+
(0, runtime_1.emitNervesEvent)({
|
|
352
|
+
level: "error",
|
|
353
|
+
event: "config_identity.error",
|
|
354
|
+
component: "config/identity",
|
|
355
|
+
message: `agent config has invalid provider in ${facingName}`,
|
|
356
|
+
meta: { path: configFile, provider: facing.provider ?? null },
|
|
357
|
+
});
|
|
358
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.provider must be one of: ${VALID_PROVIDERS.join(", ")}.`);
|
|
359
|
+
}
|
|
360
|
+
if (typeof facing.model !== "string") {
|
|
361
|
+
(0, runtime_1.emitNervesEvent)({
|
|
362
|
+
level: "error",
|
|
363
|
+
event: "config_identity.error",
|
|
364
|
+
component: "config/identity",
|
|
365
|
+
message: `agent config has invalid model in ${facingName}`,
|
|
366
|
+
meta: { path: configFile, model: facing.model ?? null },
|
|
367
|
+
});
|
|
368
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.model must be a string.`);
|
|
369
|
+
}
|
|
370
|
+
return { provider: facing.provider, model: facing.model };
|
|
371
|
+
}
|
|
372
|
+
/**
|
|
373
|
+
* Load and parse `<agentRoot>/agent.json`.
|
|
374
|
+
* Reads the file fresh on each call unless an override is set.
|
|
375
|
+
* If the config is v1, auto-migrates to v2 via migrateAgentConfigV1ToV2 and re-reads.
|
|
376
|
+
* Throws descriptive error if file is missing or contains invalid JSON.
|
|
377
|
+
*/
|
|
378
|
+
function loadAgentConfig() {
|
|
379
|
+
if (_agentConfigOverride) {
|
|
380
|
+
return _agentConfigOverride;
|
|
381
|
+
}
|
|
382
|
+
const agentRoot = getAgentRoot();
|
|
383
|
+
const configFile = path.join(agentRoot, "agent.json");
|
|
384
|
+
let parsed = readAndParseAgentJson(configFile);
|
|
385
|
+
// Inline migration: v1 -> v2
|
|
386
|
+
const rawVersion = parsed.version;
|
|
387
|
+
const initialVersion = typeof rawVersion === "number" ? rawVersion : 1;
|
|
388
|
+
if (initialVersion < 2) {
|
|
389
|
+
(0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
|
|
390
|
+
parsed = readAndParseAgentJson(configFile);
|
|
391
|
+
}
|
|
184
392
|
const existingPhrases = parsed.phrases;
|
|
185
393
|
const needsFill = !existingPhrases ||
|
|
186
394
|
!existingPhrases.thinking ||
|
|
@@ -202,27 +410,11 @@ function loadAgentConfig() {
|
|
|
202
410
|
});
|
|
203
411
|
fs.writeFileSync(configFile, JSON.stringify(parsed, null, 2) + "\n", "utf-8");
|
|
204
412
|
}
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
(0, runtime_1.emitNervesEvent)({
|
|
211
|
-
level: "error",
|
|
212
|
-
event: "config_identity.error",
|
|
213
|
-
component: "config/identity",
|
|
214
|
-
message: "agent config missing or invalid provider",
|
|
215
|
-
meta: {
|
|
216
|
-
path: configFile,
|
|
217
|
-
provider: rawProvider,
|
|
218
|
-
},
|
|
219
|
-
});
|
|
220
|
-
throw new Error(`agent.json at ${configFile} must include provider: "azure", "minimax", "anthropic", or "openai-codex".`);
|
|
221
|
-
}
|
|
222
|
-
const rawVersion = parsed.version;
|
|
223
|
-
const version = rawVersion === undefined ? 1 : rawVersion;
|
|
224
|
-
if (typeof version !== "number" ||
|
|
225
|
-
!Number.isInteger(version) ||
|
|
413
|
+
// Validate v2 facing configs
|
|
414
|
+
const humanFacing = validateFacingConfig(parsed, "humanFacing", configFile);
|
|
415
|
+
const agentFacing = validateFacingConfig(parsed, "agentFacing", configFile);
|
|
416
|
+
const version = typeof parsed.version === "number" ? parsed.version : 1;
|
|
417
|
+
if (!Number.isInteger(version) ||
|
|
226
418
|
version < 1) {
|
|
227
419
|
(0, runtime_1.emitNervesEvent)({
|
|
228
420
|
level: "error",
|
|
@@ -231,7 +423,7 @@ function loadAgentConfig() {
|
|
|
231
423
|
message: "agent config missing or invalid version",
|
|
232
424
|
meta: {
|
|
233
425
|
path: configFile,
|
|
234
|
-
version:
|
|
426
|
+
version: parsed.version,
|
|
235
427
|
},
|
|
236
428
|
});
|
|
237
429
|
throw new Error(`agent.json at ${configFile} must include version as integer >= 1.`);
|
|
@@ -251,21 +443,37 @@ function loadAgentConfig() {
|
|
|
251
443
|
});
|
|
252
444
|
throw new Error(`agent.json at ${configFile} must include enabled as boolean.`);
|
|
253
445
|
}
|
|
254
|
-
|
|
446
|
+
// Tolerate deprecated provider field for backward compatibility
|
|
447
|
+
const rawProvider = parsed.provider;
|
|
448
|
+
const provider = isValidProvider(rawProvider) ? rawProvider : undefined;
|
|
449
|
+
// Spread parsed first so any field present in AgentConfig is carried
|
|
450
|
+
// through by default, then explicitly override the fields that need
|
|
451
|
+
// validation or normalization. This eliminates the field-drop bug class
|
|
452
|
+
// that caused the `sync` block (and previously `shell`) to be silently
|
|
453
|
+
// omitted from the returned config. Regression-guarded by the
|
|
454
|
+
// Required<AgentConfig> contract test in identity-contract.test.ts.
|
|
455
|
+
const config = {
|
|
456
|
+
...parsed,
|
|
255
457
|
version,
|
|
256
458
|
enabled,
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
459
|
+
humanFacing,
|
|
460
|
+
agentFacing,
|
|
461
|
+
senses: normalizeSenses(parsed.senses, configFile),
|
|
260
462
|
phrases: parsed.phrases,
|
|
261
463
|
};
|
|
464
|
+
if (provider !== undefined) {
|
|
465
|
+
config.provider = provider;
|
|
466
|
+
}
|
|
467
|
+
else {
|
|
468
|
+
delete config.provider;
|
|
469
|
+
}
|
|
262
470
|
(0, runtime_1.emitNervesEvent)({
|
|
263
471
|
event: "identity.resolve",
|
|
264
472
|
component: "config/identity",
|
|
265
473
|
message: "loaded agent config from disk",
|
|
266
474
|
meta: { source: "disk" },
|
|
267
475
|
});
|
|
268
|
-
return
|
|
476
|
+
return config;
|
|
269
477
|
}
|
|
270
478
|
/**
|
|
271
479
|
* Prime the agent name cache explicitly.
|
|
@@ -284,12 +492,18 @@ function setAgentName(name) {
|
|
|
284
492
|
function setAgentConfigOverride(config) {
|
|
285
493
|
_agentConfigOverride = config;
|
|
286
494
|
}
|
|
495
|
+
/**
|
|
496
|
+
* Preserve the compatibility hook for callers that previously cleared cached
|
|
497
|
+
* disk-backed agent config. Agent config is now read fresh on every call.
|
|
498
|
+
*/
|
|
499
|
+
function resetAgentConfigCache() {
|
|
500
|
+
// No-op: disk-backed agent config is no longer memoized in-process.
|
|
501
|
+
}
|
|
287
502
|
/**
|
|
288
503
|
* Clear all cached identity state.
|
|
289
504
|
* Used in tests and when switching agent context.
|
|
290
505
|
*/
|
|
291
506
|
function resetIdentity() {
|
|
292
507
|
_cachedAgentName = null;
|
|
293
|
-
_cachedAgentConfig = null;
|
|
294
508
|
_agentConfigOverride = null;
|
|
295
509
|
}
|