@ouro.bot/cli 0.1.0-alpha.55 → 0.1.0-alpha.551
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 +133 -19
- 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-bootstrap-drift.md +54 -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 +3561 -0
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +140 -0
- package/dist/arc/episodes.js +117 -0
- package/dist/arc/intentions.js +133 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +237 -0
- package/dist/arc/packets.js +193 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +65 -0
- package/dist/heart/active-work.js +837 -26
- package/dist/heart/agent-entry.js +58 -3
- package/dist/heart/attachments/image-normalize.js +194 -0
- package/dist/heart/attachments/materialize.js +97 -0
- package/dist/heart/attachments/originals.js +88 -0
- package/dist/heart/attachments/render.js +29 -0
- package/dist/heart/attachments/sources/adapter.js +2 -0
- package/dist/heart/attachments/sources/bluebubbles.js +156 -0
- package/dist/heart/attachments/sources/cli-local-file.js +78 -0
- package/dist/heart/attachments/sources/index.js +16 -0
- package/dist/heart/attachments/store.js +103 -0
- package/dist/heart/attachments/types.js +93 -0
- package/dist/heart/auth/auth-flow.js +479 -0
- package/dist/heart/background-operations.js +281 -0
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +111 -0
- package/dist/heart/config-registry.js +304 -0
- package/dist/heart/config.js +114 -118
- package/dist/heart/core.js +925 -246
- package/dist/heart/cross-chat-delivery.js +3 -18
- package/dist/heart/daemon/agent-config-check.js +512 -0
- package/dist/heart/daemon/agent-discovery.js +102 -3
- package/dist/heart/daemon/agent-service.js +522 -0
- package/dist/heart/daemon/agentic-repair.js +554 -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 +665 -0
- package/dist/heart/daemon/cli-exec.js +7565 -0
- package/dist/heart/daemon/cli-help.js +498 -0
- package/dist/heart/daemon/cli-parse.js +1590 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +775 -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 -1672
- package/dist/heart/daemon/daemon-entry.js +417 -2
- package/dist/heart/daemon/daemon-health.js +183 -0
- package/dist/heart/daemon/daemon-rollup.js +58 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +87 -13
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +796 -71
- package/dist/heart/daemon/dns-workflow.js +394 -0
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +844 -0
- package/dist/heart/daemon/drift-detection.js +146 -0
- package/dist/heart/daemon/health-monitor.js +122 -1
- package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
- package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
- package/dist/heart/daemon/http-health-probe.js +80 -0
- package/dist/heart/daemon/human-command-screens.js +234 -0
- package/dist/heart/daemon/human-readiness.js +114 -0
- package/dist/heart/daemon/inner-status.js +102 -0
- package/dist/heart/daemon/interactive-repair.js +394 -0
- package/dist/heart/daemon/launchd.js +37 -8
- package/dist/heart/daemon/log-tailer.js +82 -12
- package/dist/heart/daemon/logs-prune.js +110 -0
- package/dist/heart/daemon/mcp-canary.js +297 -0
- package/dist/heart/daemon/message-router.js +2 -2
- package/dist/heart/daemon/os-cron-deps.js +135 -0
- package/dist/heart/daemon/os-cron.js +14 -12
- package/dist/heart/daemon/ouro-bot-entry.js +4 -2
- package/dist/heart/daemon/ouro-entry.js +3 -1
- package/dist/heart/daemon/process-manager.js +375 -33
- package/dist/heart/daemon/provider-discovery.js +137 -0
- package/dist/heart/daemon/provider-ping-progress.js +83 -0
- package/dist/heart/daemon/pulse.js +475 -0
- package/dist/heart/daemon/readiness-repair.js +365 -0
- package/dist/heart/daemon/run-hooks.js +2 -0
- package/dist/heart/daemon/runtime-logging.js +67 -16
- package/dist/heart/daemon/runtime-metadata.js +3 -31
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +353 -38
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +94 -0
- package/dist/heart/daemon/socket-client.js +158 -11
- package/dist/heart/daemon/stale-bundle-prune.js +96 -0
- package/dist/heart/daemon/startup-tui.js +330 -0
- package/dist/heart/daemon/task-scheduler.js +3 -25
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +162 -17
- package/dist/heart/daemon/up-progress.js +366 -0
- package/dist/heart/daemon/vault-items.js +56 -0
- package/dist/heart/delegation.js +1 -1
- package/dist/heart/habits/habit-migration.js +189 -0
- package/dist/heart/habits/habit-parser.js +140 -0
- package/dist/heart/habits/habit-runtime-state.js +100 -0
- package/dist/heart/habits/habit-scheduler.js +372 -0
- package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
- package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
- package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
- package/dist/heart/identity.js +200 -51
- package/dist/heart/kept-notes.js +357 -0
- package/dist/heart/kicks.js +1 -1
- package/dist/heart/machine-identity.js +161 -0
- package/dist/heart/mail-import-discovery.js +353 -0
- package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
- package/dist/heart/mailbox/mailbox-http-response.js +7 -0
- package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
- package/dist/heart/mailbox/mailbox-http-static.js +103 -0
- package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
- package/dist/heart/mailbox/mailbox-http.js +99 -0
- package/dist/heart/mailbox/mailbox-read.js +31 -0
- package/dist/heart/mailbox/mailbox-types.js +27 -0
- package/dist/heart/mailbox/mailbox-view.js +195 -0
- package/dist/heart/mailbox/readers/agent-machine.js +382 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
- package/dist/heart/mailbox/readers/mail.js +362 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +651 -0
- package/dist/heart/mailbox/readers/sessions.js +232 -0
- package/dist/heart/mailbox/readers/shared.js +111 -0
- package/dist/heart/mcp/mcp-server.js +683 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +19 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +255 -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-state.js +216 -0
- package/dist/heart/provider-visibility.js +188 -0
- package/dist/heart/providers/anthropic-token.js +131 -0
- package/dist/heart/providers/anthropic.js +139 -52
- package/dist/heart/providers/azure.js +97 -13
- package/dist/heart/providers/error-classification.js +127 -0
- package/dist/heart/providers/github-copilot.js +145 -0
- package/dist/heart/providers/minimax-vlm.js +189 -0
- package/dist/heart/providers/minimax.js +26 -8
- package/dist/heart/providers/openai-codex.js +55 -40
- package/dist/heart/runtime-capability-check.js +170 -0
- package/dist/heart/runtime-credentials.js +367 -0
- package/dist/heart/runtime-cwd.js +87 -0
- package/dist/heart/sense-truth.js +11 -4
- package/dist/heart/session-activity.js +43 -22
- package/dist/heart/session-events.js +1149 -0
- package/dist/heart/session-playback-cli-main.js +5 -0
- package/dist/heart/session-playback-cli.js +36 -0
- package/dist/heart/session-playback.js +231 -0
- package/dist/heart/session-stats-cli-main.js +5 -0
- package/dist/heart/session-stats.js +182 -0
- package/dist/heart/session-transcript.js +243 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +44 -27
- package/dist/heart/sync-classification.js +176 -0
- package/dist/heart/sync.js +449 -0
- package/dist/heart/target-resolution.js +9 -5
- package/dist/heart/tempo.js +93 -0
- package/dist/heart/temporal-view.js +41 -0
- package/dist/heart/timeouts.js +101 -0
- package/dist/heart/tool-activity-callbacks.js +59 -0
- package/dist/heart/tool-description.js +139 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +381 -0
- package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +6 -5
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +426 -0
- package/dist/heart/versioning/ouro-version-manager.js +295 -0
- package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
- package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
- package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
- package/dist/mailbox-ui/assets/index-BPr5vNuM.css +1 -0
- package/dist/mailbox-ui/assets/index-Cm51CY9W.js +61 -0
- package/dist/mailbox-ui/index.html +15 -0
- package/dist/mailroom/attention.js +167 -0
- package/dist/mailroom/autonomy.js +209 -0
- package/dist/mailroom/blob-store.js +674 -0
- package/dist/mailroom/body-cache.js +61 -0
- package/dist/mailroom/core.js +720 -0
- package/dist/mailroom/entry.js +160 -0
- package/dist/mailroom/file-store.js +430 -0
- package/dist/mailroom/mbox-import.js +383 -0
- package/dist/mailroom/outbound.js +380 -0
- package/dist/mailroom/policy.js +263 -0
- package/dist/mailroom/reader.js +233 -0
- package/dist/mailroom/search-cache.js +256 -0
- package/dist/mailroom/search-relevance.js +319 -0
- package/dist/mailroom/smtp-ingress.js +176 -0
- package/dist/mailroom/source-state.js +176 -0
- package/dist/mailroom/thread.js +109 -0
- package/dist/mailroom/travel-extract.js +89 -0
- package/dist/mind/bundle-manifest.js +7 -1
- package/dist/mind/context.js +165 -101
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +62 -75
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/friends/channel.js +30 -0
- package/dist/mind/friends/resolver.js +54 -2
- package/dist/mind/friends/store-file.js +39 -3
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/journal-index.js +161 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +4 -0
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +995 -123
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/nerves/cli-logging.js +7 -1
- package/dist/nerves/coverage/audit-rules.js +15 -6
- package/dist/nerves/coverage/audit.js +28 -2
- package/dist/nerves/coverage/cli.js +1 -1
- package/dist/nerves/coverage/contract.js +5 -5
- package/dist/nerves/coverage/file-completeness.js +139 -5
- package/dist/nerves/coverage/run-artifacts.js +1 -1
- package/dist/nerves/event-buffer.js +111 -0
- package/dist/nerves/index.js +224 -4
- package/dist/nerves/observation.js +20 -0
- package/dist/nerves/redact.js +79 -0
- package/dist/nerves/review/cli-main.js +5 -0
- package/dist/nerves/review/cli.js +156 -0
- package/dist/nerves/review/core.js +152 -0
- package/dist/nerves/runtime.js +5 -1
- package/dist/repertoire/ado-client.js +15 -56
- package/dist/repertoire/ado-semantic.js +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +816 -0
- package/dist/repertoire/bundle-templates.js +72 -0
- package/dist/repertoire/bw-installer.js +180 -0
- package/dist/repertoire/coding/codex-jsonl.js +64 -0
- package/dist/repertoire/coding/context-pack.js +330 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +158 -9
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +170 -7
- package/dist/repertoire/commerce-errors.js +109 -0
- package/dist/repertoire/commerce-self-test.js +156 -0
- package/dist/repertoire/credential-access.js +111 -0
- package/dist/repertoire/duffel-client.js +185 -0
- package/dist/repertoire/github-client.js +14 -55
- package/dist/repertoire/graph-client.js +11 -52
- package/dist/repertoire/guardrails.js +396 -0
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +362 -0
- package/dist/repertoire/mcp-tools.js +63 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +15 -24
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tasks/board.js +31 -5
- package/dist/repertoire/tasks/fix.js +182 -0
- package/dist/repertoire/tasks/index.js +16 -4
- package/dist/repertoire/tasks/lifecycle.js +2 -2
- package/dist/repertoire/tasks/parser.js +3 -2
- package/dist/repertoire/tasks/scanner.js +194 -37
- package/dist/repertoire/tasks/transitions.js +16 -78
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-base.js +47 -1075
- package/dist/repertoire/tools-bluebubbles.js +1 -0
- package/dist/repertoire/tools-bridge.js +142 -0
- package/dist/repertoire/tools-bundle.js +984 -0
- package/dist/repertoire/tools-config.js +185 -0
- package/dist/repertoire/tools-continuity.js +248 -0
- package/dist/repertoire/tools-credential.js +381 -0
- package/dist/repertoire/tools-files.js +342 -0
- package/dist/repertoire/tools-flight.js +224 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +1 -7
- package/dist/repertoire/tools-mail.js +1857 -0
- package/dist/repertoire/tools-notes.js +421 -0
- package/dist/repertoire/tools-session.js +750 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +180 -0
- package/dist/repertoire/tools-surface.js +243 -0
- package/dist/repertoire/tools-teams.js +9 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +604 -0
- package/dist/repertoire/tools-user-profile.js +144 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools.js +108 -100
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +131 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +561 -0
- package/dist/scripts/claude-code-hook.js +41 -0
- package/dist/scripts/claude-code-stop-hook.js +47 -0
- package/dist/senses/attention-queue.js +116 -0
- package/dist/senses/bluebubbles/active-turns.js +216 -0
- package/dist/senses/bluebubbles/attachment-cache.js +53 -0
- package/dist/senses/bluebubbles/attachment-download.js +137 -0
- package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
- package/dist/senses/bluebubbles/entry.js +77 -0
- package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
- package/dist/senses/bluebubbles/index.js +2305 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
- package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
- package/dist/senses/bluebubbles/processed-log.js +133 -0
- package/dist/senses/bluebubbles/replay.js +137 -0
- package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
- package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
- package/dist/senses/cli/bracketed-paste.js +82 -0
- package/dist/senses/cli/image-paste.js +287 -0
- package/dist/senses/cli/image-ref-navigation.js +75 -0
- package/dist/senses/cli/ink-app.js +156 -0
- package/dist/senses/cli/inline-diff.js +64 -0
- package/dist/senses/cli/input-keys.js +174 -0
- package/dist/senses/cli/kill-ring.js +86 -0
- package/dist/senses/cli/message-list.js +51 -0
- package/dist/senses/cli/ouro-tui.js +607 -0
- package/dist/senses/cli/spinner-imperative.js +135 -0
- package/dist/senses/cli/spinner.js +101 -0
- package/dist/senses/cli/status-line.js +60 -0
- package/dist/senses/cli/streaming-markdown.js +526 -0
- package/dist/senses/cli/tool-display.js +85 -0
- package/dist/senses/cli/tool-render.js +85 -0
- package/dist/senses/cli/tui-store.js +240 -0
- package/dist/senses/cli/virtual-list.js +35 -0
- package/dist/senses/cli-entry.js +60 -8
- package/dist/senses/cli-layout.js +187 -0
- package/dist/senses/cli.js +520 -209
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +175 -21
- package/dist/senses/inner-dialog.js +330 -27
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +569 -182
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +248 -0
- package/dist/senses/surface-tool.js +68 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +387 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +146 -0
- package/package.json +38 -7
- package/skills/agent-commerce.md +106 -0
- package/skills/browser-navigation.md +117 -0
- package/skills/commerce-setup-guide.md +116 -0
- package/skills/commerce-setup.md +84 -0
- package/skills/configure-dev-tools.md +101 -0
- package/skills/travel-planning.md +138 -0
- package/dist/heart/daemon/ouro-path-installer.js +0 -178
- package/dist/heart/daemon/subagent-installer.js +0 -166
- package/dist/heart/session-recall.js +0 -116
- package/dist/mind/associative-recall.js +0 -209
- package/dist/senses/bluebubbles-entry.js +0 -13
- package/dist/senses/bluebubbles.js +0 -1177
- package/dist/senses/debug-activity.js +0 -148
- package/subagents/README.md +0 -86
- package/subagents/work-doer.md +0 -237
- package/subagents/work-merger.md +0 -618
- package/subagents/work-planner.md +0 -390
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
- /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
- /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
- /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
- /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
|
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.buildSpecialistSystemPrompt = buildSpecialistSystemPrompt;
|
|
4
4
|
const runtime_1 = require("../../nerves/runtime");
|
|
5
5
|
/**
|
|
6
|
-
* Build the
|
|
6
|
+
* Build the serpent guide's system prompt from its components.
|
|
7
7
|
* The prompt is written in first person (the specialist's own voice).
|
|
8
8
|
*/
|
|
9
9
|
function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, context) {
|
|
@@ -31,7 +31,7 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
31
31
|
"I am one of thirteen serpent guides who help humans hatch their first agent. The system randomly selected me for this session.",
|
|
32
32
|
"Most humans only go through this process once, so this is likely the only time they'll meet me.",
|
|
33
33
|
"I make this encounter count — warm, memorable, and uniquely mine.",
|
|
34
|
-
"IMPORTANT: I NEVER refer to myself
|
|
34
|
+
"IMPORTANT: I NEVER refer to myself by internal implementation labels — I introduce myself by my own name from my identity.",
|
|
35
35
|
"",
|
|
36
36
|
"## Voice rules",
|
|
37
37
|
"IMPORTANT: I keep every response to 1-3 short sentences. I sound like a friend texting, not a manual.",
|
|
@@ -44,7 +44,7 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
44
44
|
`Provider: ${context.provider}`,
|
|
45
45
|
`Temp directory: ${context.tempDir}`,
|
|
46
46
|
"Final home: ~/AgentBundles/<Name>.ouro/",
|
|
47
|
-
"
|
|
47
|
+
"Provider credentials: the hatch tool stores them in the agent's vault.",
|
|
48
48
|
].join("\n"));
|
|
49
49
|
sections.push([
|
|
50
50
|
"## Bundle creation guidelines",
|
|
@@ -59,8 +59,10 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
59
59
|
"It also needs an **agent.json** with at minimum:",
|
|
60
60
|
'```json',
|
|
61
61
|
'{',
|
|
62
|
+
' "version": 2,',
|
|
62
63
|
' "name": "AgentName",',
|
|
63
|
-
` "provider": "${context.provider}",`,
|
|
64
|
+
` "humanFacing": { "provider": "${context.provider}", "model": "${context.model}" },`,
|
|
65
|
+
` "agentFacing": { "provider": "${context.provider}", "model": "${context.model}" },`,
|
|
64
66
|
' "enabled": true',
|
|
65
67
|
'}',
|
|
66
68
|
'```',
|
|
@@ -82,18 +84,19 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
82
84
|
"2. I write agent.json to the temp directory using write_file",
|
|
83
85
|
"3. I suggest a PascalCase name for the hatchling and confirm with the human",
|
|
84
86
|
"4. I call complete_adoption with the name and a warm handoff message",
|
|
85
|
-
"5. I call
|
|
87
|
+
"5. I call settle to end the session",
|
|
86
88
|
].join("\n"));
|
|
87
89
|
sections.push([
|
|
88
90
|
"## Tools",
|
|
89
91
|
"- `write_file`: Write a file to disk. Use this to write psyche files and agent.json to the temp directory.",
|
|
90
92
|
"- `read_file`: Read a file from disk. Useful for reviewing existing agent bundles or migration sources.",
|
|
91
93
|
"- `list_directory`: List directory contents. Useful for exploring existing agent bundles.",
|
|
92
|
-
"- I also have the normal local harness tools when useful here, including `shell`, `ouro task create`, `ouro reminder create`,
|
|
93
|
-
"- `complete_adoption`: Finalize the bundle. Validates, scaffolds structural dirs, moves to ~/AgentBundles/, writes secrets, plays hatch animation. I call this with `name` (PascalCase) and `handoff_message` (warm message for the human).",
|
|
94
|
-
"-
|
|
94
|
+
"- I also have the normal local harness tools when useful here, including `shell`, `ouro task create`, `ouro reminder create`, note tools, coding tools, and repo helpers.",
|
|
95
|
+
"- `complete_adoption`: Finalize the bundle. Validates, asks the harness to collect and confirm the hatchling vault unlock secret through hidden terminal prompts, scaffolds structural dirs, moves to ~/AgentBundles/, writes secrets, plays hatch animation. I call this with `name` (PascalCase) and `handoff_message` (warm message for the human).",
|
|
96
|
+
"- The complete_adoption tool triggers hidden terminal prompts for the hatchling vault unlock secret. I must never ask the human to type the vault unlock secret into chat, and I must never include it in tool arguments.",
|
|
97
|
+
"- `settle`: End the conversation with a final message. I call this after complete_adoption succeeds.",
|
|
95
98
|
"",
|
|
96
|
-
"I must call `
|
|
99
|
+
"I must call `settle` when I am done to end the session cleanly.",
|
|
97
100
|
].join("\n"));
|
|
98
101
|
return sections.join("\n\n");
|
|
99
102
|
}
|
|
@@ -35,19 +35,21 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
36
|
exports.getSpecialistTools = getSpecialistTools;
|
|
37
37
|
exports.createSpecialistExecTool = createSpecialistExecTool;
|
|
38
|
-
const crypto = __importStar(require("crypto"));
|
|
39
38
|
const fs = __importStar(require("fs"));
|
|
40
39
|
const path = __importStar(require("path"));
|
|
41
40
|
const tools_base_1 = require("../../repertoire/tools-base");
|
|
42
41
|
const hatch_flow_1 = require("./hatch-flow");
|
|
43
42
|
const hatch_animation_1 = require("./hatch-animation");
|
|
44
43
|
const bundle_manifest_1 = require("../../mind/bundle-manifest");
|
|
44
|
+
const identity_1 = require("../identity");
|
|
45
45
|
const runtime_1 = require("../../nerves/runtime");
|
|
46
|
+
const vault_setup_1 = require("../../repertoire/vault-setup");
|
|
47
|
+
const vault_unlock_1 = require("../../repertoire/vault-unlock");
|
|
46
48
|
const completeAdoptionTool = {
|
|
47
49
|
type: "function",
|
|
48
50
|
function: {
|
|
49
51
|
name: "complete_adoption",
|
|
50
|
-
description: "finalize the agent bundle and hatch the new agent. call this only when you have written all 5 psyche files and agent.json to the temp directory, and the human has approved the bundle.",
|
|
52
|
+
description: "finalize the agent bundle and hatch the new agent. call this only when you have written all 5 psyche files and agent.json to the temp directory, and the human has approved the bundle. tool execution asks the human for the hatchling vault unlock secret through a hidden terminal prompt; do not ask for or include vault unlock secrets in chat or tool args.",
|
|
51
53
|
parameters: {
|
|
52
54
|
type: "object",
|
|
53
55
|
properties: {
|
|
@@ -90,7 +92,7 @@ const listDirToolSchema = {
|
|
|
90
92
|
* Returns the specialist's tool schema array.
|
|
91
93
|
*/
|
|
92
94
|
function getSpecialistTools() {
|
|
93
|
-
return [completeAdoptionTool, tools_base_1.
|
|
95
|
+
return [completeAdoptionTool, tools_base_1.settleTool, readFileTool.tool, writeFileTool.tool, listDirToolSchema];
|
|
94
96
|
}
|
|
95
97
|
const PSYCHE_FILES = ["SOUL.md", "IDENTITY.md", "LORE.md", "TACIT.md", "ASPIRATIONS.md"];
|
|
96
98
|
function isPascalCase(name) {
|
|
@@ -105,21 +107,21 @@ function writeReadme(dir, purpose) {
|
|
|
105
107
|
}
|
|
106
108
|
}
|
|
107
109
|
function scaffoldBundle(bundleRoot) {
|
|
108
|
-
writeReadme(path.join(bundleRoot, "
|
|
109
|
-
writeReadme(path.join(bundleRoot, "
|
|
110
|
-
writeReadme(path.join(bundleRoot, "
|
|
110
|
+
writeReadme(path.join(bundleRoot, "notes"), "Persistent notes store.");
|
|
111
|
+
writeReadme(path.join(bundleRoot, "notes", "daily"), "Daily note entries.");
|
|
112
|
+
writeReadme(path.join(bundleRoot, "notes", "archive"), "Archived notes.");
|
|
111
113
|
writeReadme(path.join(bundleRoot, "friends"), "Known friend records.");
|
|
112
114
|
writeReadme(path.join(bundleRoot, "tasks"), "Task files.");
|
|
113
|
-
writeReadme(path.join(bundleRoot, "tasks", "habits"), "Recurring tasks.");
|
|
114
115
|
writeReadme(path.join(bundleRoot, "tasks", "one-shots"), "One-shot tasks.");
|
|
116
|
+
writeReadme(path.join(bundleRoot, "habits"), "Recurring habits and autonomous rhythms.");
|
|
115
117
|
writeReadme(path.join(bundleRoot, "tasks", "ongoing"), "Ongoing tasks.");
|
|
116
118
|
writeReadme(path.join(bundleRoot, "skills"), "Local skill files.");
|
|
117
119
|
writeReadme(path.join(bundleRoot, "senses"), "Sense-specific config.");
|
|
118
120
|
writeReadme(path.join(bundleRoot, "senses", "teams"), "Teams sense config.");
|
|
119
|
-
//
|
|
120
|
-
const
|
|
121
|
-
const factsPath = path.join(
|
|
122
|
-
const entitiesPath = path.join(
|
|
121
|
+
// Notes scaffold files
|
|
122
|
+
const notesRoot = path.join(bundleRoot, "notes");
|
|
123
|
+
const factsPath = path.join(notesRoot, "facts.jsonl");
|
|
124
|
+
const entitiesPath = path.join(notesRoot, "entities.json");
|
|
123
125
|
/* v8 ignore next -- defensive: guard against re-scaffold on existing bundle @preserve */
|
|
124
126
|
if (!fs.existsSync(factsPath))
|
|
125
127
|
fs.writeFileSync(factsPath, "", "utf-8");
|
|
@@ -166,13 +168,34 @@ async function execCompleteAdoption(args, deps) {
|
|
|
166
168
|
if (fs.existsSync(targetBundle)) {
|
|
167
169
|
return `error: bundle '${name}.ouro' already exists at ${deps.bundlesRoot}. choose a different name.`;
|
|
168
170
|
}
|
|
171
|
+
if (!deps.promptSecret) {
|
|
172
|
+
return "error: complete_adoption requires an interactive vault unlock secret prompt. Re-run `ouro hatch` in a terminal so the human can enter a hatchling vault unlock secret without echoing it.";
|
|
173
|
+
}
|
|
174
|
+
const vault = (0, identity_1.resolveVaultConfig)(name);
|
|
175
|
+
let vaultUnlockSecret;
|
|
176
|
+
try {
|
|
177
|
+
vaultUnlockSecret = await (0, vault_unlock_1.promptConfirmedVaultUnlockSecret)({
|
|
178
|
+
promptSecret: deps.promptSecret,
|
|
179
|
+
question: `Choose Ouro vault unlock secret for ${vault.email}: `,
|
|
180
|
+
confirmQuestion: `Confirm Ouro vault unlock secret for ${vault.email}: `,
|
|
181
|
+
emptyError: "hatchling vault creation requires an unlock secret. Re-run `ouro hatch` in an interactive terminal and enter a human-chosen unlock secret.",
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
catch (error) {
|
|
185
|
+
return `error: failed to read hatchling vault unlock secret: ${error instanceof Error ? error.message : /* v8 ignore next -- defensive: non-Error catch branch @preserve */ String(error)}`;
|
|
186
|
+
}
|
|
169
187
|
// Scaffold structural dirs into tempDir
|
|
170
188
|
scaffoldBundle(deps.tempDir);
|
|
171
189
|
// Move tempDir -> final bundle location
|
|
172
190
|
moveDir(deps.tempDir, targetBundle);
|
|
173
191
|
// Write secrets
|
|
174
192
|
try {
|
|
175
|
-
(0,
|
|
193
|
+
const vaultResult = await (0, vault_setup_1.createVaultAccount)(name, vault.serverUrl, vault.email, vaultUnlockSecret);
|
|
194
|
+
if (!vaultResult.success) {
|
|
195
|
+
throw new Error(`failed to create vault: ${vaultResult.error}`);
|
|
196
|
+
}
|
|
197
|
+
(0, vault_unlock_1.storeVaultUnlockSecret)({ agentName: name, email: vault.email, serverUrl: vault.serverUrl }, vaultUnlockSecret);
|
|
198
|
+
await (0, hatch_flow_1.storeHatchlingProviderCredentials)(name, deps.provider, deps.credentials);
|
|
176
199
|
}
|
|
177
200
|
catch (e) {
|
|
178
201
|
// Rollback: remove the moved bundle
|
package/dist/heart/identity.js
CHANGED
|
@@ -33,14 +33,25 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
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;
|
|
40
45
|
exports.getAgentBundlesRoot = getAgentBundlesRoot;
|
|
41
46
|
exports.getAgentRoot = getAgentRoot;
|
|
42
47
|
exports.getAgentStateRoot = getAgentStateRoot;
|
|
43
|
-
exports.
|
|
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;
|
|
44
55
|
exports.loadAgentConfig = loadAgentConfig;
|
|
45
56
|
exports.setAgentName = setAgentName;
|
|
46
57
|
exports.setAgentConfigOverride = setAgentConfigOverride;
|
|
@@ -50,6 +61,15 @@ const fs = __importStar(require("fs"));
|
|
|
50
61
|
const os = __importStar(require("os"));
|
|
51
62
|
const path = __importStar(require("path"));
|
|
52
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
|
+
};
|
|
53
73
|
exports.DEFAULT_AGENT_CONTEXT = {
|
|
54
74
|
maxTokens: 80000,
|
|
55
75
|
contextMargin: 20,
|
|
@@ -59,16 +79,70 @@ exports.DEFAULT_AGENT_PHRASES = {
|
|
|
59
79
|
tool: ["running tool"],
|
|
60
80
|
followup: ["processing"],
|
|
61
81
|
};
|
|
82
|
+
exports.DEFAULT_VAULT_SERVER_URL = "https://vault.ouroboros.bot";
|
|
83
|
+
exports.LEGACY_VAULT_SERVER_URL_ALIASES = [
|
|
84
|
+
"https://vault.ouro.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
|
+
}
|
|
62
134
|
exports.DEFAULT_AGENT_SENSES = {
|
|
63
135
|
cli: { enabled: true },
|
|
64
136
|
teams: { enabled: false },
|
|
65
137
|
bluebubbles: { enabled: false },
|
|
138
|
+
mail: { enabled: false },
|
|
66
139
|
};
|
|
67
140
|
function normalizeSenses(value, configFile) {
|
|
68
141
|
const defaults = {
|
|
69
142
|
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
70
143
|
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
71
144
|
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
145
|
+
mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
|
|
72
146
|
};
|
|
73
147
|
if (value === undefined) {
|
|
74
148
|
return defaults;
|
|
@@ -84,7 +158,7 @@ function normalizeSenses(value, configFile) {
|
|
|
84
158
|
throw new Error(`agent.json at ${configFile} must include senses as an object when present.`);
|
|
85
159
|
}
|
|
86
160
|
const raw = value;
|
|
87
|
-
const senseNames = ["cli", "teams", "bluebubbles"];
|
|
161
|
+
const senseNames = ["cli", "teams", "bluebubbles", "mail"];
|
|
88
162
|
for (const senseName of senseNames) {
|
|
89
163
|
const rawSense = raw[senseName];
|
|
90
164
|
if (rawSense === undefined) {
|
|
@@ -117,14 +191,16 @@ function normalizeSenses(value, configFile) {
|
|
|
117
191
|
}
|
|
118
192
|
function buildDefaultAgentTemplate(_agentName) {
|
|
119
193
|
return {
|
|
120
|
-
version:
|
|
194
|
+
version: 2,
|
|
121
195
|
enabled: true,
|
|
122
|
-
provider: "anthropic",
|
|
196
|
+
humanFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
197
|
+
agentFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
123
198
|
context: { ...exports.DEFAULT_AGENT_CONTEXT },
|
|
124
199
|
senses: {
|
|
125
200
|
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
126
201
|
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
127
202
|
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
203
|
+
mail: { ...exports.DEFAULT_AGENT_SENSES.mail },
|
|
128
204
|
},
|
|
129
205
|
phrases: {
|
|
130
206
|
thinking: [...exports.DEFAULT_AGENT_PHRASES.thinking],
|
|
@@ -184,29 +260,49 @@ function getAgentBundlesRoot() {
|
|
|
184
260
|
function getAgentRoot(agentName = getAgentName()) {
|
|
185
261
|
return path.join(getAgentBundlesRoot(), `${agentName}.ouro`);
|
|
186
262
|
}
|
|
263
|
+
function resolveOptionalAgentName(agentName) {
|
|
264
|
+
if (agentName && agentName.trim().length > 0)
|
|
265
|
+
return agentName.trim();
|
|
266
|
+
try {
|
|
267
|
+
return getAgentName();
|
|
268
|
+
}
|
|
269
|
+
catch {
|
|
270
|
+
return "slugger";
|
|
271
|
+
}
|
|
272
|
+
}
|
|
187
273
|
/**
|
|
188
274
|
* Returns the bundle-local runtime state directory: `~/AgentBundles/<agentName>.ouro/state/`
|
|
189
275
|
*/
|
|
190
|
-
function getAgentStateRoot(agentName
|
|
191
|
-
return path.join(getAgentRoot(agentName), "state");
|
|
276
|
+
function getAgentStateRoot(agentName) {
|
|
277
|
+
return path.join(getAgentRoot(resolveOptionalAgentName(agentName)), "state");
|
|
192
278
|
}
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
function getAgentSecretsPath(agentName = getAgentName()) {
|
|
197
|
-
return path.join(os.homedir(), ".agentsecrets", agentName, "secrets.json");
|
|
279
|
+
exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/ouroborosbot/ouroboros.git";
|
|
280
|
+
function getAgentRepoWorkspacesRoot(agentName) {
|
|
281
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "workspaces");
|
|
198
282
|
}
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
283
|
+
function getAgentDaemonStateRoot(agentName) {
|
|
284
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "daemon");
|
|
285
|
+
}
|
|
286
|
+
function getAgentDaemonLogsDir(agentName) {
|
|
287
|
+
return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logs");
|
|
288
|
+
}
|
|
289
|
+
function getAgentDaemonLoggingConfigPath(agentName) {
|
|
290
|
+
return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logging.json");
|
|
291
|
+
}
|
|
292
|
+
function getAgentMessagesRoot(agentName) {
|
|
293
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "messages");
|
|
294
|
+
}
|
|
295
|
+
function getAgentMailroomRoot(agentName) {
|
|
296
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "mailroom");
|
|
297
|
+
}
|
|
298
|
+
function getAgentToolsRoot(agentName) {
|
|
299
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "tools");
|
|
300
|
+
}
|
|
301
|
+
const VALID_PROVIDERS = ["azure", "minimax", "anthropic", "openai-codex", "github-copilot"];
|
|
302
|
+
function isValidProvider(value) {
|
|
303
|
+
return typeof value === "string" && VALID_PROVIDERS.includes(value);
|
|
304
|
+
}
|
|
305
|
+
function readAndParseAgentJson(configFile) {
|
|
210
306
|
let raw;
|
|
211
307
|
try {
|
|
212
308
|
raw = fs.readFileSync(configFile, "utf-8");
|
|
@@ -224,9 +320,8 @@ function loadAgentConfig() {
|
|
|
224
320
|
});
|
|
225
321
|
throw new Error(`Cannot read agent.json at ${configFile}. Does the agent directory exist?`);
|
|
226
322
|
}
|
|
227
|
-
let parsed;
|
|
228
323
|
try {
|
|
229
|
-
|
|
324
|
+
return JSON.parse(raw);
|
|
230
325
|
}
|
|
231
326
|
catch (error) {
|
|
232
327
|
(0, runtime_1.emitNervesEvent)({
|
|
@@ -241,6 +336,62 @@ function loadAgentConfig() {
|
|
|
241
336
|
});
|
|
242
337
|
throw new Error(`Invalid JSON in agent.json at ${configFile}. Check syntax.`);
|
|
243
338
|
}
|
|
339
|
+
}
|
|
340
|
+
function validateFacingConfig(parsed, facingName, configFile) {
|
|
341
|
+
const raw = parsed[facingName];
|
|
342
|
+
if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
|
|
343
|
+
(0, runtime_1.emitNervesEvent)({
|
|
344
|
+
level: "error",
|
|
345
|
+
event: "config_identity.error",
|
|
346
|
+
component: "config/identity",
|
|
347
|
+
message: `agent config missing or invalid ${facingName}`,
|
|
348
|
+
meta: { path: configFile, [facingName]: raw ?? null },
|
|
349
|
+
});
|
|
350
|
+
throw new Error(`agent.json at ${configFile} must include ${facingName} as { provider, model }.`);
|
|
351
|
+
}
|
|
352
|
+
const facing = raw;
|
|
353
|
+
if (!isValidProvider(facing.provider)) {
|
|
354
|
+
(0, runtime_1.emitNervesEvent)({
|
|
355
|
+
level: "error",
|
|
356
|
+
event: "config_identity.error",
|
|
357
|
+
component: "config/identity",
|
|
358
|
+
message: `agent config has invalid provider in ${facingName}`,
|
|
359
|
+
meta: { path: configFile, provider: facing.provider ?? null },
|
|
360
|
+
});
|
|
361
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.provider must be one of: ${VALID_PROVIDERS.join(", ")}.`);
|
|
362
|
+
}
|
|
363
|
+
if (typeof facing.model !== "string") {
|
|
364
|
+
(0, runtime_1.emitNervesEvent)({
|
|
365
|
+
level: "error",
|
|
366
|
+
event: "config_identity.error",
|
|
367
|
+
component: "config/identity",
|
|
368
|
+
message: `agent config has invalid model in ${facingName}`,
|
|
369
|
+
meta: { path: configFile, model: facing.model ?? null },
|
|
370
|
+
});
|
|
371
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.model must be a string.`);
|
|
372
|
+
}
|
|
373
|
+
return { provider: facing.provider, model: facing.model };
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* Load and parse `<agentRoot>/agent.json`.
|
|
377
|
+
* Reads the file fresh on each call unless an override is set.
|
|
378
|
+
* If the config is v1, auto-migrates to v2 via migrateAgentConfigV1ToV2 and re-reads.
|
|
379
|
+
* Throws descriptive error if file is missing or contains invalid JSON.
|
|
380
|
+
*/
|
|
381
|
+
function loadAgentConfig() {
|
|
382
|
+
if (_agentConfigOverride) {
|
|
383
|
+
return _agentConfigOverride;
|
|
384
|
+
}
|
|
385
|
+
const agentRoot = getAgentRoot();
|
|
386
|
+
const configFile = path.join(agentRoot, "agent.json");
|
|
387
|
+
let parsed = readAndParseAgentJson(configFile);
|
|
388
|
+
// Inline migration: v1 -> v2
|
|
389
|
+
const rawVersion = parsed.version;
|
|
390
|
+
const initialVersion = typeof rawVersion === "number" ? rawVersion : 1;
|
|
391
|
+
if (initialVersion < 2) {
|
|
392
|
+
(0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
|
|
393
|
+
parsed = readAndParseAgentJson(configFile);
|
|
394
|
+
}
|
|
244
395
|
const existingPhrases = parsed.phrases;
|
|
245
396
|
const needsFill = !existingPhrases ||
|
|
246
397
|
!existingPhrases.thinking ||
|
|
@@ -262,28 +413,11 @@ function loadAgentConfig() {
|
|
|
262
413
|
});
|
|
263
414
|
fs.writeFileSync(configFile, JSON.stringify(parsed, null, 2) + "\n", "utf-8");
|
|
264
415
|
}
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
(0, runtime_1.emitNervesEvent)({
|
|
271
|
-
level: "error",
|
|
272
|
-
event: "config_identity.error",
|
|
273
|
-
component: "config/identity",
|
|
274
|
-
message: "agent config missing or invalid provider",
|
|
275
|
-
meta: {
|
|
276
|
-
path: configFile,
|
|
277
|
-
provider: rawProvider,
|
|
278
|
-
},
|
|
279
|
-
});
|
|
280
|
-
throw new Error(`agent.json at ${configFile} must include provider: "azure", "minimax", "anthropic", or "openai-codex".`);
|
|
281
|
-
}
|
|
282
|
-
const provider = rawProvider;
|
|
283
|
-
const rawVersion = parsed.version;
|
|
284
|
-
const version = rawVersion === undefined ? 1 : rawVersion;
|
|
285
|
-
if (typeof version !== "number" ||
|
|
286
|
-
!Number.isInteger(version) ||
|
|
416
|
+
// Validate v2 facing configs
|
|
417
|
+
const humanFacing = validateFacingConfig(parsed, "humanFacing", configFile);
|
|
418
|
+
const agentFacing = validateFacingConfig(parsed, "agentFacing", configFile);
|
|
419
|
+
const version = typeof parsed.version === "number" ? parsed.version : 1;
|
|
420
|
+
if (!Number.isInteger(version) ||
|
|
287
421
|
version < 1) {
|
|
288
422
|
(0, runtime_1.emitNervesEvent)({
|
|
289
423
|
level: "error",
|
|
@@ -292,7 +426,7 @@ function loadAgentConfig() {
|
|
|
292
426
|
message: "agent config missing or invalid version",
|
|
293
427
|
meta: {
|
|
294
428
|
path: configFile,
|
|
295
|
-
version:
|
|
429
|
+
version: parsed.version,
|
|
296
430
|
},
|
|
297
431
|
});
|
|
298
432
|
throw new Error(`agent.json at ${configFile} must include version as integer >= 1.`);
|
|
@@ -312,15 +446,30 @@ function loadAgentConfig() {
|
|
|
312
446
|
});
|
|
313
447
|
throw new Error(`agent.json at ${configFile} must include enabled as boolean.`);
|
|
314
448
|
}
|
|
449
|
+
// Tolerate deprecated provider field for backward compatibility
|
|
450
|
+
const rawProvider = parsed.provider;
|
|
451
|
+
const provider = isValidProvider(rawProvider) ? rawProvider : undefined;
|
|
452
|
+
// Spread parsed first so any field present in AgentConfig is carried
|
|
453
|
+
// through by default, then explicitly override the fields that need
|
|
454
|
+
// validation or normalization. This eliminates the field-drop bug class
|
|
455
|
+
// that caused the `sync` block (and previously `shell`) to be silently
|
|
456
|
+
// omitted from the returned config. Regression-guarded by the
|
|
457
|
+
// Required<AgentConfig> contract test in identity-contract.test.ts.
|
|
315
458
|
const config = {
|
|
459
|
+
...parsed,
|
|
316
460
|
version,
|
|
317
461
|
enabled,
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
logging: parsed.logging,
|
|
462
|
+
humanFacing,
|
|
463
|
+
agentFacing,
|
|
321
464
|
senses: normalizeSenses(parsed.senses, configFile),
|
|
322
465
|
phrases: parsed.phrases,
|
|
323
466
|
};
|
|
467
|
+
if (provider !== undefined) {
|
|
468
|
+
config.provider = provider;
|
|
469
|
+
}
|
|
470
|
+
else {
|
|
471
|
+
delete config.provider;
|
|
472
|
+
}
|
|
324
473
|
(0, runtime_1.emitNervesEvent)({
|
|
325
474
|
event: "identity.resolve",
|
|
326
475
|
component: "config/identity",
|