@ouro.bot/cli 0.1.0-alpha.56 → 0.1.0-alpha.561
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +127 -23
- package/RepairGuide.ouro/agent.json +5 -0
- package/RepairGuide.ouro/psyche/IDENTITY.md +19 -0
- package/RepairGuide.ouro/psyche/SOUL.md +55 -0
- package/RepairGuide.ouro/skills/diagnose-broken-remote.md +63 -0
- package/RepairGuide.ouro/skills/diagnose-stacked-typed-issues.md +35 -0
- package/RepairGuide.ouro/skills/diagnose-sync-blocked.md +54 -0
- package/RepairGuide.ouro/skills/diagnose-vault-expired.md +60 -0
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +4 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
- package/changelog.json +3604 -0
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +140 -0
- package/dist/arc/episodes.js +117 -0
- package/dist/arc/intentions.js +133 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +237 -0
- package/dist/arc/packets.js +193 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +65 -0
- package/dist/heart/active-work.js +837 -26
- package/dist/heart/agent-entry.js +58 -3
- package/dist/heart/attachments/image-normalize.js +194 -0
- package/dist/heart/attachments/materialize.js +97 -0
- package/dist/heart/attachments/originals.js +88 -0
- package/dist/heart/attachments/render.js +29 -0
- package/dist/heart/attachments/sources/adapter.js +2 -0
- package/dist/heart/attachments/sources/bluebubbles.js +156 -0
- package/dist/heart/attachments/sources/cli-local-file.js +78 -0
- package/dist/heart/attachments/sources/index.js +16 -0
- package/dist/heart/attachments/store.js +103 -0
- package/dist/heart/attachments/types.js +93 -0
- package/dist/heart/auth/auth-flow.js +479 -0
- package/dist/heart/background-operations.js +281 -0
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +111 -0
- package/dist/heart/config-registry.js +322 -0
- package/dist/heart/config.js +114 -118
- package/dist/heart/core.js +913 -246
- package/dist/heart/cross-chat-delivery.js +3 -18
- package/dist/heart/daemon/agent-config-check.js +419 -0
- package/dist/heart/daemon/agent-discovery.js +102 -3
- package/dist/heart/daemon/agent-service.js +522 -0
- package/dist/heart/daemon/agentic-repair.js +547 -0
- package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
- package/dist/heart/daemon/boot-sync-probe.js +197 -0
- package/dist/heart/daemon/cadence.js +70 -0
- package/dist/heart/daemon/cli-defaults.js +776 -0
- package/dist/heart/daemon/cli-exec.js +7457 -0
- package/dist/heart/daemon/cli-help.js +498 -0
- package/dist/heart/daemon/cli-parse.js +1592 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +763 -0
- package/dist/heart/daemon/cli-types.js +8 -0
- package/dist/heart/daemon/connect-bay.js +323 -0
- package/dist/heart/daemon/daemon-cli.js +29 -1698
- package/dist/heart/daemon/daemon-entry.js +387 -2
- package/dist/heart/daemon/daemon-health.js +176 -0
- package/dist/heart/daemon/daemon-rollup.js +57 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +88 -13
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +796 -71
- package/dist/heart/daemon/dns-workflow.js +394 -0
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +826 -0
- package/dist/heart/daemon/health-monitor.js +122 -1
- package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
- package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
- package/dist/heart/daemon/http-health-probe.js +80 -0
- package/dist/heart/daemon/human-command-screens.js +234 -0
- package/dist/heart/daemon/human-readiness.js +114 -0
- package/dist/heart/daemon/inner-status.js +89 -0
- package/dist/heart/daemon/interactive-repair.js +394 -0
- package/dist/heart/daemon/launchd.js +37 -8
- package/dist/heart/daemon/log-tailer.js +82 -12
- package/dist/heart/daemon/logs-prune.js +110 -0
- package/dist/heart/daemon/mcp-canary.js +297 -0
- package/dist/heart/daemon/message-router.js +2 -2
- package/dist/heart/daemon/os-cron-deps.js +135 -0
- package/dist/heart/daemon/os-cron.js +14 -12
- package/dist/heart/daemon/ouro-bot-entry.js +4 -2
- package/dist/heart/daemon/ouro-entry.js +3 -1
- package/dist/heart/daemon/process-manager.js +375 -33
- package/dist/heart/daemon/provider-discovery.js +137 -0
- package/dist/heart/daemon/provider-ping-progress.js +83 -0
- package/dist/heart/daemon/pulse.js +475 -0
- package/dist/heart/daemon/readiness-repair.js +365 -0
- package/dist/heart/daemon/run-hooks.js +2 -0
- package/dist/heart/daemon/runtime-logging.js +67 -16
- package/dist/heart/daemon/runtime-metadata.js +3 -31
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +389 -38
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +94 -0
- package/dist/heart/daemon/socket-client.js +158 -11
- package/dist/heart/daemon/stale-bundle-prune.js +96 -0
- package/dist/heart/daemon/startup-tui.js +330 -0
- package/dist/heart/daemon/task-scheduler.js +3 -25
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +162 -17
- package/dist/heart/daemon/up-progress.js +366 -0
- package/dist/heart/daemon/vault-items.js +56 -0
- package/dist/heart/delegation.js +1 -1
- package/dist/heart/habits/habit-migration.js +189 -0
- package/dist/heart/habits/habit-parser.js +140 -0
- package/dist/heart/habits/habit-runtime-state.js +100 -0
- package/dist/heart/habits/habit-scheduler.js +372 -0
- package/dist/heart/{daemon → hatch}/hatch-flow.js +32 -56
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
- package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
- package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
- package/dist/heart/identity.js +203 -57
- package/dist/heart/kept-notes.js +357 -0
- package/dist/heart/kicks.js +1 -1
- package/dist/heart/machine-identity.js +161 -0
- package/dist/heart/mail-import-discovery.js +353 -0
- package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
- package/dist/heart/mailbox/mailbox-http-response.js +7 -0
- package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
- package/dist/heart/mailbox/mailbox-http-static.js +103 -0
- package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
- package/dist/heart/mailbox/mailbox-http.js +99 -0
- package/dist/heart/mailbox/mailbox-read.js +31 -0
- package/dist/heart/mailbox/mailbox-types.js +27 -0
- package/dist/heart/mailbox/mailbox-view.js +195 -0
- package/dist/heart/mailbox/readers/agent-machine.js +382 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
- package/dist/heart/mailbox/readers/mail.js +362 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +651 -0
- package/dist/heart/mailbox/readers/sessions.js +232 -0
- package/dist/heart/mailbox/readers/shared.js +111 -0
- package/dist/heart/mcp/mcp-server.js +683 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +19 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +267 -0
- package/dist/heart/provider-credentials.js +425 -0
- package/dist/heart/provider-failover.js +301 -0
- package/dist/heart/provider-models.js +81 -0
- package/dist/heart/provider-ping.js +262 -0
- package/dist/heart/provider-readiness-cache.js +40 -0
- package/dist/heart/provider-visibility.js +188 -0
- package/dist/heart/providers/anthropic-token.js +131 -0
- package/dist/heart/providers/anthropic.js +139 -52
- package/dist/heart/providers/azure.js +97 -13
- package/dist/heart/providers/error-classification.js +127 -0
- package/dist/heart/providers/github-copilot.js +145 -0
- package/dist/heart/providers/minimax-vlm.js +189 -0
- package/dist/heart/providers/minimax.js +26 -8
- package/dist/heart/providers/openai-codex.js +55 -40
- package/dist/heart/runtime-capability-check.js +170 -0
- package/dist/heart/runtime-credentials.js +367 -0
- package/dist/heart/runtime-cwd.js +87 -0
- package/dist/heart/sense-truth.js +13 -4
- package/dist/heart/session-activity.js +43 -22
- package/dist/heart/session-events.js +1149 -0
- package/dist/heart/session-playback-cli-main.js +5 -0
- package/dist/heart/session-playback-cli.js +36 -0
- package/dist/heart/session-playback.js +231 -0
- package/dist/heart/session-stats-cli-main.js +5 -0
- package/dist/heart/session-stats.js +182 -0
- package/dist/heart/session-transcript.js +243 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +44 -27
- package/dist/heart/sync-classification.js +176 -0
- package/dist/heart/sync.js +449 -0
- package/dist/heart/target-resolution.js +9 -5
- package/dist/heart/tempo.js +93 -0
- package/dist/heart/temporal-view.js +41 -0
- package/dist/heart/timeouts.js +101 -0
- package/dist/heart/tool-activity-callbacks.js +59 -0
- package/dist/heart/tool-description.js +139 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +389 -0
- package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +6 -5
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +426 -0
- package/dist/heart/versioning/ouro-version-manager.js +295 -0
- package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
- package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
- package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
- package/dist/mailbox-ui/assets/index-B-461hes.js +61 -0
- package/dist/mailbox-ui/assets/index-BPr5vNuM.css +1 -0
- package/dist/mailbox-ui/index.html +15 -0
- package/dist/mailroom/attention.js +167 -0
- package/dist/mailroom/autonomy.js +209 -0
- package/dist/mailroom/blob-store.js +674 -0
- package/dist/mailroom/body-cache.js +61 -0
- package/dist/mailroom/core.js +720 -0
- package/dist/mailroom/entry.js +160 -0
- package/dist/mailroom/file-store.js +430 -0
- package/dist/mailroom/mbox-import.js +383 -0
- package/dist/mailroom/outbound.js +380 -0
- package/dist/mailroom/policy.js +263 -0
- package/dist/mailroom/reader.js +233 -0
- package/dist/mailroom/search-cache.js +256 -0
- package/dist/mailroom/search-relevance.js +319 -0
- package/dist/mailroom/smtp-ingress.js +176 -0
- package/dist/mailroom/source-state.js +176 -0
- package/dist/mailroom/thread.js +109 -0
- package/dist/mailroom/travel-extract.js +89 -0
- package/dist/mind/bundle-manifest.js +7 -1
- package/dist/mind/context.js +165 -101
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +62 -75
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/friends/channel.js +39 -0
- package/dist/mind/friends/resolver.js +54 -2
- package/dist/mind/friends/store-file.js +39 -3
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/journal-index.js +161 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +4 -0
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1011 -123
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/nerves/cli-logging.js +7 -1
- package/dist/nerves/coverage/audit-rules.js +15 -6
- package/dist/nerves/coverage/audit.js +28 -2
- package/dist/nerves/coverage/cli.js +1 -1
- package/dist/nerves/coverage/contract.js +5 -5
- package/dist/nerves/coverage/file-completeness.js +129 -5
- package/dist/nerves/coverage/run-artifacts.js +1 -1
- package/dist/nerves/event-buffer.js +111 -0
- package/dist/nerves/index.js +224 -4
- package/dist/nerves/observation.js +20 -0
- package/dist/nerves/redact.js +79 -0
- package/dist/nerves/review/cli-main.js +5 -0
- package/dist/nerves/review/cli.js +156 -0
- package/dist/nerves/review/core.js +152 -0
- package/dist/nerves/runtime.js +5 -1
- package/dist/repertoire/ado-client.js +15 -56
- package/dist/repertoire/ado-semantic.js +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +963 -0
- package/dist/repertoire/bundle-templates.js +72 -0
- package/dist/repertoire/bw-installer.js +180 -0
- package/dist/repertoire/coding/codex-jsonl.js +64 -0
- package/dist/repertoire/coding/context-pack.js +330 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +158 -9
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +170 -7
- package/dist/repertoire/commerce-errors.js +109 -0
- package/dist/repertoire/commerce-self-test.js +156 -0
- package/dist/repertoire/credential-access.js +178 -0
- package/dist/repertoire/duffel-client.js +185 -0
- package/dist/repertoire/github-client.js +14 -55
- package/dist/repertoire/graph-client.js +11 -52
- package/dist/repertoire/guardrails.js +396 -0
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +362 -0
- package/dist/repertoire/mcp-tools.js +63 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +15 -24
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tasks/board.js +31 -5
- package/dist/repertoire/tasks/fix.js +182 -0
- package/dist/repertoire/tasks/index.js +16 -4
- package/dist/repertoire/tasks/lifecycle.js +2 -2
- package/dist/repertoire/tasks/parser.js +3 -2
- package/dist/repertoire/tasks/scanner.js +194 -37
- package/dist/repertoire/tasks/transitions.js +16 -78
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-base.js +47 -1075
- package/dist/repertoire/tools-bluebubbles.js +1 -0
- package/dist/repertoire/tools-bridge.js +142 -0
- package/dist/repertoire/tools-bundle.js +984 -0
- package/dist/repertoire/tools-config.js +185 -0
- package/dist/repertoire/tools-continuity.js +248 -0
- package/dist/repertoire/tools-credential.js +381 -0
- package/dist/repertoire/tools-files.js +342 -0
- package/dist/repertoire/tools-flight.js +224 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +1 -7
- package/dist/repertoire/tools-mail.js +1857 -0
- package/dist/repertoire/tools-notes.js +421 -0
- package/dist/repertoire/tools-session.js +750 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +180 -0
- package/dist/repertoire/tools-surface.js +243 -0
- package/dist/repertoire/tools-teams.js +9 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +604 -0
- package/dist/repertoire/tools-user-profile.js +144 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools.js +108 -100
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +131 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +594 -0
- package/dist/scripts/claude-code-hook.js +41 -0
- package/dist/scripts/claude-code-stop-hook.js +47 -0
- package/dist/senses/attention-queue.js +116 -0
- package/dist/senses/bluebubbles/active-turns.js +216 -0
- package/dist/senses/bluebubbles/attachment-cache.js +53 -0
- package/dist/senses/bluebubbles/attachment-download.js +137 -0
- package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
- package/dist/senses/bluebubbles/entry.js +77 -0
- package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
- package/dist/senses/bluebubbles/index.js +2305 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
- package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
- package/dist/senses/bluebubbles/processed-log.js +133 -0
- package/dist/senses/bluebubbles/replay.js +137 -0
- package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
- package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
- package/dist/senses/cli/bracketed-paste.js +82 -0
- package/dist/senses/cli/image-paste.js +287 -0
- package/dist/senses/cli/image-ref-navigation.js +75 -0
- package/dist/senses/cli/ink-app.js +156 -0
- package/dist/senses/cli/inline-diff.js +64 -0
- package/dist/senses/cli/input-keys.js +174 -0
- package/dist/senses/cli/kill-ring.js +86 -0
- package/dist/senses/cli/message-list.js +51 -0
- package/dist/senses/cli/ouro-tui.js +607 -0
- package/dist/senses/cli/spinner-imperative.js +135 -0
- package/dist/senses/cli/spinner.js +101 -0
- package/dist/senses/cli/status-line.js +60 -0
- package/dist/senses/cli/streaming-markdown.js +526 -0
- package/dist/senses/cli/tool-display.js +85 -0
- package/dist/senses/cli/tool-render.js +85 -0
- package/dist/senses/cli/tui-store.js +240 -0
- package/dist/senses/cli/virtual-list.js +35 -0
- package/dist/senses/cli-entry.js +60 -8
- package/dist/senses/cli-layout.js +187 -0
- package/dist/senses/cli.js +520 -209
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +175 -21
- package/dist/senses/inner-dialog.js +330 -27
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +549 -181
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +251 -0
- package/dist/senses/surface-tool.js +68 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +387 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/senses/voice/audio-routing.js +119 -0
- package/dist/senses/voice/elevenlabs.js +178 -0
- package/dist/senses/voice/golden-path.js +116 -0
- package/dist/senses/voice/index.js +26 -0
- package/dist/senses/voice/meeting.js +113 -0
- package/dist/senses/voice/playback.js +139 -0
- package/dist/senses/voice/transcript.js +70 -0
- package/dist/senses/voice/turn.js +85 -0
- package/dist/senses/voice/types.js +2 -0
- package/dist/senses/voice/whisper.js +161 -0
- package/dist/senses/voice-entry.js +80 -0
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +146 -0
- package/package.json +38 -7
- package/skills/agent-commerce.md +106 -0
- package/skills/browser-navigation.md +117 -0
- package/skills/commerce-setup-guide.md +116 -0
- package/skills/commerce-setup.md +84 -0
- package/skills/configure-dev-tools.md +101 -0
- package/skills/travel-planning.md +138 -0
- package/dist/heart/daemon/auth-flow.js +0 -351
- package/dist/heart/daemon/ouro-path-installer.js +0 -178
- package/dist/heart/daemon/subagent-installer.js +0 -166
- package/dist/heart/session-recall.js +0 -116
- package/dist/mind/associative-recall.js +0 -209
- package/dist/senses/bluebubbles-entry.js +0 -13
- package/dist/senses/bluebubbles.js +0 -1177
- package/dist/senses/debug-activity.js +0 -148
- package/subagents/README.md +0 -86
- package/subagents/work-doer.md +0 -237
- package/subagents/work-merger.md +0 -618
- package/subagents/work-planner.md +0 -390
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
- /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
- /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
- /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
- /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
|
@@ -0,0 +1,479 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.readAgentConfigForAgent = readAgentConfigForAgent;
|
|
37
|
+
exports.writeAgentProviderSelection = writeAgentProviderSelection;
|
|
38
|
+
exports.storeProviderCredentials = storeProviderCredentials;
|
|
39
|
+
exports.writeAgentModel = writeAgentModel;
|
|
40
|
+
exports.collectRuntimeAuthCredentials = collectRuntimeAuthCredentials;
|
|
41
|
+
exports.resolveHatchCredentials = resolveHatchCredentials;
|
|
42
|
+
exports.runRuntimeAuthFlow = runRuntimeAuthFlow;
|
|
43
|
+
const child_process_1 = require("child_process");
|
|
44
|
+
const fs = __importStar(require("fs"));
|
|
45
|
+
const os = __importStar(require("os"));
|
|
46
|
+
const path = __importStar(require("path"));
|
|
47
|
+
const runtime_1 = require("../../nerves/runtime");
|
|
48
|
+
const identity_1 = require("../identity");
|
|
49
|
+
const migrate_config_1 = require("../migrate-config");
|
|
50
|
+
const provider_models_1 = require("../provider-models");
|
|
51
|
+
const provider_credentials_1 = require("../provider-credentials");
|
|
52
|
+
const vault_unlock_1 = require("../../repertoire/vault-unlock");
|
|
53
|
+
const ANTHROPIC_SETUP_TOKEN_PREFIX = "sk-ant-oat01-";
|
|
54
|
+
const ANTHROPIC_SETUP_TOKEN_MIN_LENGTH = 80;
|
|
55
|
+
const CODEX_LOCAL_TOKEN_REFRESH_MARGIN_MS = 5 * 60 * 1000;
|
|
56
|
+
function assertPersistentProviderCredentialsAllowed(agentName) {
|
|
57
|
+
if (agentName === "SerpentGuide") {
|
|
58
|
+
throw new Error("SerpentGuide uses provider credentials in memory during hatch bootstrap; persistent SerpentGuide auth is not supported.");
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
function readJsonRecord(filePath, label) {
|
|
62
|
+
try {
|
|
63
|
+
const raw = fs.readFileSync(filePath, "utf8");
|
|
64
|
+
const parsed = JSON.parse(raw);
|
|
65
|
+
if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
|
|
66
|
+
throw new Error("expected object");
|
|
67
|
+
}
|
|
68
|
+
return parsed;
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
throw new Error(`Failed to read ${label} at ${filePath}: ${String(error)}`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
function readAgentConfigForAgent(agentName, bundlesRoot = (0, identity_1.getAgentBundlesRoot)()) {
|
|
75
|
+
const agentRoot = path.join(bundlesRoot, `${agentName}.ouro`);
|
|
76
|
+
const configPath = path.join(agentRoot, "agent.json");
|
|
77
|
+
let parsed = readJsonRecord(configPath, "agent config");
|
|
78
|
+
// Inline migration: v1 -> v2
|
|
79
|
+
const version = typeof parsed.version === "number" ? parsed.version : 1;
|
|
80
|
+
if (version < 2) {
|
|
81
|
+
(0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
|
|
82
|
+
parsed = readJsonRecord(configPath, "agent config");
|
|
83
|
+
}
|
|
84
|
+
// Validate v2 required facing fields
|
|
85
|
+
const humanFacing = parsed.humanFacing;
|
|
86
|
+
const agentFacing = parsed.agentFacing;
|
|
87
|
+
if (!humanFacing || typeof humanFacing !== "object") {
|
|
88
|
+
throw new Error(`agent.json at ${configPath} has unsupported provider '${String(parsed.provider)}'`);
|
|
89
|
+
}
|
|
90
|
+
const provider = humanFacing.provider;
|
|
91
|
+
if (provider !== "azure" &&
|
|
92
|
+
provider !== "anthropic" &&
|
|
93
|
+
provider !== "minimax" &&
|
|
94
|
+
provider !== "openai-codex" &&
|
|
95
|
+
provider !== "github-copilot") {
|
|
96
|
+
throw new Error(`agent.json at ${configPath} has unsupported provider '${String(provider)}'`);
|
|
97
|
+
}
|
|
98
|
+
if (!agentFacing || typeof agentFacing !== "object") {
|
|
99
|
+
throw new Error(`agent.json at ${configPath} has unsupported provider '${String(parsed.provider)}'`);
|
|
100
|
+
}
|
|
101
|
+
// Spread-with-validation: same pattern as loadAgentConfig to eliminate
|
|
102
|
+
// the unvalidated-pass-through bug class. The spread carries through
|
|
103
|
+
// every field present in parsed; senses goes through the same
|
|
104
|
+
// normalization as loadAgentConfig so the two entry points return
|
|
105
|
+
// equivalent configs for the same file.
|
|
106
|
+
const config = {
|
|
107
|
+
...parsed,
|
|
108
|
+
senses: (0, identity_1.normalizeSenses)(parsed.senses, configPath),
|
|
109
|
+
};
|
|
110
|
+
return {
|
|
111
|
+
configPath,
|
|
112
|
+
config,
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
function writeAgentProviderSelection(agentName, facing, provider, bundlesRoot = (0, identity_1.getAgentBundlesRoot)()) {
|
|
116
|
+
const { configPath, config } = readAgentConfigForAgent(agentName, bundlesRoot);
|
|
117
|
+
const facingKey = facing === "human" ? "humanFacing" : "agentFacing";
|
|
118
|
+
const previousFacing = config[facingKey];
|
|
119
|
+
const resolved = (0, provider_models_1.resolveModelForProviderSelection)(provider, previousFacing.model);
|
|
120
|
+
const nextConfig = {
|
|
121
|
+
...config,
|
|
122
|
+
[facingKey]: { ...previousFacing, provider, model: resolved.model },
|
|
123
|
+
};
|
|
124
|
+
fs.writeFileSync(configPath, `${JSON.stringify(nextConfig, null, 2)}\n`, "utf8");
|
|
125
|
+
(0, runtime_1.emitNervesEvent)({
|
|
126
|
+
component: "daemon",
|
|
127
|
+
event: "daemon.auth_provider_selected",
|
|
128
|
+
message: "updated agent provider selection after auth flow",
|
|
129
|
+
meta: {
|
|
130
|
+
agentName,
|
|
131
|
+
facing,
|
|
132
|
+
provider,
|
|
133
|
+
previousProvider: previousFacing.provider,
|
|
134
|
+
previousModel: previousFacing.model,
|
|
135
|
+
model: resolved.model,
|
|
136
|
+
preservedModel: resolved.preserved,
|
|
137
|
+
configPath,
|
|
138
|
+
},
|
|
139
|
+
});
|
|
140
|
+
return configPath;
|
|
141
|
+
}
|
|
142
|
+
async function storeProviderCredentials(agentName, provider, credentials, deps = {}) {
|
|
143
|
+
assertPersistentProviderCredentialsAllowed(agentName);
|
|
144
|
+
const split = (0, provider_credentials_1.splitProviderCredentialFields)(provider, credentials);
|
|
145
|
+
await (0, provider_credentials_1.upsertProviderCredential)({
|
|
146
|
+
agentName,
|
|
147
|
+
provider,
|
|
148
|
+
credentials: split.credentials,
|
|
149
|
+
config: split.config,
|
|
150
|
+
provenance: { source: "auth-flow" },
|
|
151
|
+
now: deps.now,
|
|
152
|
+
onProgress: deps.onProgress,
|
|
153
|
+
});
|
|
154
|
+
return { credentialPath: (0, provider_credentials_1.providerCredentialItemName)(provider) };
|
|
155
|
+
}
|
|
156
|
+
function writeAgentModel(agentName, facing, modelName, deps = {}) {
|
|
157
|
+
const { configPath, config } = readAgentConfigForAgent(agentName, deps.bundlesRoot);
|
|
158
|
+
const facingKey = facing === "human" ? "humanFacing" : "agentFacing";
|
|
159
|
+
const facingBlock = config[facingKey];
|
|
160
|
+
const previousModel = facingBlock.model;
|
|
161
|
+
const provider = facingBlock.provider;
|
|
162
|
+
const nextConfig = {
|
|
163
|
+
...config,
|
|
164
|
+
[facingKey]: { ...facingBlock, model: modelName },
|
|
165
|
+
};
|
|
166
|
+
fs.writeFileSync(configPath, `${JSON.stringify(nextConfig, null, 2)}\n`, "utf8");
|
|
167
|
+
(0, runtime_1.emitNervesEvent)({
|
|
168
|
+
component: "daemon",
|
|
169
|
+
event: "daemon.config_model_updated",
|
|
170
|
+
message: "updated agent model in agent.json",
|
|
171
|
+
meta: { agentName, facing, provider, modelName, previousModel, configPath },
|
|
172
|
+
});
|
|
173
|
+
return { configPath, provider, previousModel };
|
|
174
|
+
}
|
|
175
|
+
function decodeJwtPayload(token) {
|
|
176
|
+
const parts = token.split(".");
|
|
177
|
+
if (parts.length < 2 || !parts[1])
|
|
178
|
+
return null;
|
|
179
|
+
try {
|
|
180
|
+
const base64 = parts[1]
|
|
181
|
+
.replace(/-/g, "+")
|
|
182
|
+
.replace(/_/g, "/")
|
|
183
|
+
.padEnd(Math.ceil(parts[1].length / 4) * 4, "=");
|
|
184
|
+
const parsed = JSON.parse(Buffer.from(base64, "base64").toString("utf8"));
|
|
185
|
+
if (!parsed || typeof parsed !== "object" || Array.isArray(parsed))
|
|
186
|
+
return null;
|
|
187
|
+
return parsed;
|
|
188
|
+
}
|
|
189
|
+
catch {
|
|
190
|
+
return null;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
function readJwtExpiresAt(token) {
|
|
194
|
+
const payload = decodeJwtPayload(token);
|
|
195
|
+
const exp = payload?.exp;
|
|
196
|
+
if (typeof exp !== "number" || !Number.isFinite(exp) || exp <= 0)
|
|
197
|
+
return undefined;
|
|
198
|
+
return Math.floor(exp * 1000);
|
|
199
|
+
}
|
|
200
|
+
function isFreshCodexToken(credentials, now) {
|
|
201
|
+
if (!credentials.oauthAccessToken)
|
|
202
|
+
return false;
|
|
203
|
+
if (typeof credentials.expiresAt !== "number")
|
|
204
|
+
return false;
|
|
205
|
+
return credentials.expiresAt > now.getTime() + CODEX_LOCAL_TOKEN_REFRESH_MARGIN_MS;
|
|
206
|
+
}
|
|
207
|
+
function readCodexLocalAuthCredentials(homeDir) {
|
|
208
|
+
const authPath = path.join(homeDir, ".codex", "auth.json");
|
|
209
|
+
try {
|
|
210
|
+
const raw = fs.readFileSync(authPath, "utf8");
|
|
211
|
+
const parsed = JSON.parse(raw);
|
|
212
|
+
const accessToken = typeof parsed.tokens?.access_token === "string" ? parsed.tokens.access_token.trim() : "";
|
|
213
|
+
if (!accessToken)
|
|
214
|
+
return {};
|
|
215
|
+
const refreshToken = typeof parsed.tokens?.refresh_token === "string" ? parsed.tokens.refresh_token.trim() : "";
|
|
216
|
+
const expiresAt = readJwtExpiresAt(accessToken);
|
|
217
|
+
return {
|
|
218
|
+
oauthAccessToken: accessToken,
|
|
219
|
+
...(refreshToken ? { refreshToken } : {}),
|
|
220
|
+
...(expiresAt ? { expiresAt } : {}),
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
catch {
|
|
224
|
+
return {};
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
function isCodexLoginStatusReady(result) {
|
|
228
|
+
if (result.error || result.status !== 0)
|
|
229
|
+
return false;
|
|
230
|
+
const output = `${typeof result.stdout === "string" ? result.stdout : ""}\n${typeof result.stderr === "string" ? result.stderr : ""}`;
|
|
231
|
+
return output.toLowerCase().includes("logged in");
|
|
232
|
+
}
|
|
233
|
+
function ensurePromptInput(promptInput, provider) {
|
|
234
|
+
if (promptInput)
|
|
235
|
+
return promptInput;
|
|
236
|
+
throw new Error(`No prompt input is available for ${provider} authentication.`);
|
|
237
|
+
}
|
|
238
|
+
function writeAuthProgress(input, message) {
|
|
239
|
+
input.onProgress?.(message);
|
|
240
|
+
}
|
|
241
|
+
function isVaultStoreUnlockError(message) {
|
|
242
|
+
return (message.includes("bw CLI could not use the local Bitwarden session because it is locked, missing, or expired") ||
|
|
243
|
+
message.includes("bw CLI rejected the saved vault unlock secret for this machine"));
|
|
244
|
+
}
|
|
245
|
+
function formatVaultStoreError(agentName, provider, error) {
|
|
246
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
247
|
+
if (message.startsWith("credential stored in vault, but the in-memory provider credential pool could not be refreshed:")) {
|
|
248
|
+
return new Error(`provider authentication succeeded and ${provider} credentials were stored in ${agentName}'s vault, ` +
|
|
249
|
+
`but the in-memory provider credential pool refresh failed: ${message.replace("credential stored in vault, but the in-memory provider credential pool could not be refreshed: ", "")}`);
|
|
250
|
+
}
|
|
251
|
+
const retry = `Then retry 'ouro auth --agent ${agentName} --provider ${provider}'.`;
|
|
252
|
+
if (isVaultStoreUnlockError(message)) {
|
|
253
|
+
return new Error(`provider authentication succeeded, but storing ${provider} credentials in ${agentName}'s vault failed: ${message}\n` +
|
|
254
|
+
(0, vault_unlock_1.vaultUnlockReplaceRecoverFix)(agentName, retry));
|
|
255
|
+
}
|
|
256
|
+
return new Error(`provider authentication succeeded, but storing ${provider} credentials in ${agentName}'s vault failed: ${message}\n${retry}`);
|
|
257
|
+
}
|
|
258
|
+
function validateAnthropicToken(token) {
|
|
259
|
+
const trimmed = token.trim();
|
|
260
|
+
if (!trimmed) {
|
|
261
|
+
throw new Error("No Anthropic setup token was provided.");
|
|
262
|
+
}
|
|
263
|
+
if (!trimmed.startsWith(ANTHROPIC_SETUP_TOKEN_PREFIX)) {
|
|
264
|
+
throw new Error(`Invalid Anthropic setup token format. Expected prefix ${ANTHROPIC_SETUP_TOKEN_PREFIX}.`);
|
|
265
|
+
}
|
|
266
|
+
if (trimmed.length < ANTHROPIC_SETUP_TOKEN_MIN_LENGTH) {
|
|
267
|
+
throw new Error("Anthropic setup token looks too short.");
|
|
268
|
+
}
|
|
269
|
+
return trimmed;
|
|
270
|
+
}
|
|
271
|
+
async function collectRuntimeAuthCredentials(input, deps) {
|
|
272
|
+
const spawnSync = deps.spawnSync ?? child_process_1.spawnSync;
|
|
273
|
+
const homeDir = deps.homeDir ?? os.homedir();
|
|
274
|
+
const now = deps.now ?? (() => new Date());
|
|
275
|
+
if (input.provider === "github-copilot") {
|
|
276
|
+
let token = process.env.GH_TOKEN?.trim() || process.env.GITHUB_TOKEN?.trim() || "";
|
|
277
|
+
if (!token) {
|
|
278
|
+
writeAuthProgress(input, "checking GitHub CLI credentials...");
|
|
279
|
+
const result = spawnSync("gh", ["auth", "token"], { encoding: "utf8" });
|
|
280
|
+
token = (result.status === 0 && result.stdout ? result.stdout.trim() : "");
|
|
281
|
+
}
|
|
282
|
+
if (!token) {
|
|
283
|
+
writeAuthProgress(input, "starting GitHub login...");
|
|
284
|
+
(0, runtime_1.emitNervesEvent)({
|
|
285
|
+
component: "daemon",
|
|
286
|
+
event: "daemon.auth_gh_login_start",
|
|
287
|
+
message: "starting gh auth login for runtime auth",
|
|
288
|
+
meta: { agentName: input.agentName },
|
|
289
|
+
});
|
|
290
|
+
const loginResult = spawnSync("gh", ["auth", "login"], { stdio: "inherit" });
|
|
291
|
+
if (loginResult.status !== 0) {
|
|
292
|
+
throw new Error("'gh auth login' failed. Install the GitHub CLI (gh) and try again.");
|
|
293
|
+
}
|
|
294
|
+
const retryResult = spawnSync("gh", ["auth", "token"], { encoding: "utf8" });
|
|
295
|
+
/* v8 ignore next -- branch: retry after login always succeeds in tests @preserve */
|
|
296
|
+
token = (retryResult.status === 0 && retryResult.stdout ? retryResult.stdout.trim() : "");
|
|
297
|
+
/* v8 ignore next -- defensive: gh auth login succeeded but token still missing @preserve */
|
|
298
|
+
if (!token) {
|
|
299
|
+
throw new Error("gh auth login completed but no token was found. Run `gh auth login` and try again.");
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
writeAuthProgress(input, "checking GitHub Copilot access...");
|
|
303
|
+
const response = await fetch("https://api.github.com/copilot_internal/user", {
|
|
304
|
+
headers: { Authorization: `Bearer ${token}` },
|
|
305
|
+
});
|
|
306
|
+
if (!response.ok) {
|
|
307
|
+
throw new Error(`GitHub Copilot endpoint discovery failed (HTTP ${response.status}). Ensure your GitHub account has Copilot access.`);
|
|
308
|
+
}
|
|
309
|
+
const body = await response.json();
|
|
310
|
+
const baseUrl = body?.endpoints?.api;
|
|
311
|
+
/* v8 ignore next -- defensive: valid response but missing endpoints field @preserve */
|
|
312
|
+
if (!baseUrl) {
|
|
313
|
+
throw new Error("GitHub Copilot endpoint discovery returned no endpoints.api. Ensure your GitHub account has Copilot access.");
|
|
314
|
+
}
|
|
315
|
+
return { githubToken: token, baseUrl };
|
|
316
|
+
}
|
|
317
|
+
if (input.provider === "openai-codex") {
|
|
318
|
+
writeAuthProgress(input, "checking local Codex login...");
|
|
319
|
+
const localStatus = spawnSync("codex", ["login", "status"], { encoding: "utf8" });
|
|
320
|
+
const localCredentials = readCodexLocalAuthCredentials(homeDir);
|
|
321
|
+
if (isCodexLoginStatusReady(localStatus) && isFreshCodexToken(localCredentials, now())) {
|
|
322
|
+
writeAuthProgress(input, "using existing openai-codex local login...");
|
|
323
|
+
return localCredentials;
|
|
324
|
+
}
|
|
325
|
+
(0, runtime_1.emitNervesEvent)({
|
|
326
|
+
component: "daemon",
|
|
327
|
+
event: "daemon.auth_codex_login_start",
|
|
328
|
+
message: "starting codex login for runtime auth",
|
|
329
|
+
meta: { agentName: input.agentName },
|
|
330
|
+
});
|
|
331
|
+
writeAuthProgress(input, "starting openai-codex browser login...");
|
|
332
|
+
const result = spawnSync("codex", ["login"], { stdio: "inherit" });
|
|
333
|
+
if (result.error) {
|
|
334
|
+
throw new Error(`Failed to run 'codex login': ${result.error.message}`);
|
|
335
|
+
}
|
|
336
|
+
if (result.status !== 0) {
|
|
337
|
+
throw new Error(`'codex login' exited with status ${result.status}.`);
|
|
338
|
+
}
|
|
339
|
+
writeAuthProgress(input, "openai-codex login complete; reading local Codex token...");
|
|
340
|
+
const credentials = readCodexLocalAuthCredentials(homeDir);
|
|
341
|
+
if (!credentials.oauthAccessToken) {
|
|
342
|
+
throw new Error("Codex login completed but no token was found in ~/.codex/auth.json. Re-run `codex login` and try again.");
|
|
343
|
+
}
|
|
344
|
+
return credentials;
|
|
345
|
+
}
|
|
346
|
+
if (input.provider === "anthropic") {
|
|
347
|
+
(0, runtime_1.emitNervesEvent)({
|
|
348
|
+
component: "daemon",
|
|
349
|
+
event: "daemon.auth_claude_setup_start",
|
|
350
|
+
message: "starting claude setup-token for runtime auth",
|
|
351
|
+
meta: { agentName: input.agentName },
|
|
352
|
+
});
|
|
353
|
+
writeAuthProgress(input, "starting anthropic setup-token flow...");
|
|
354
|
+
const result = spawnSync("claude", ["setup-token"], { stdio: "inherit" });
|
|
355
|
+
if (result.error) {
|
|
356
|
+
throw new Error(`Failed to run 'claude setup-token': ${result.error.message}`);
|
|
357
|
+
}
|
|
358
|
+
if (result.status !== 0) {
|
|
359
|
+
throw new Error(`'claude setup-token' exited with status ${result.status}.`);
|
|
360
|
+
}
|
|
361
|
+
const prompt = ensurePromptInput(input.promptInput, input.provider);
|
|
362
|
+
const setupToken = validateAnthropicToken(await prompt("Paste the setup token from `claude setup-token`: "));
|
|
363
|
+
// Exchange the setup token for an access+refresh token pair so auto-refresh works.
|
|
364
|
+
// The setup token IS the initial access token — we use it as a refresh token to
|
|
365
|
+
// get back a proper token pair from the OAuth endpoint.
|
|
366
|
+
/* v8 ignore start -- token exchange: requires live Anthropic OAuth endpoint @preserve */
|
|
367
|
+
try {
|
|
368
|
+
const { refreshAnthropicToken } = await Promise.resolve().then(() => __importStar(require("../providers/anthropic-token")));
|
|
369
|
+
writeAuthProgress(input, "exchanging anthropic setup token...");
|
|
370
|
+
const tokenState = await refreshAnthropicToken(setupToken);
|
|
371
|
+
if (tokenState) {
|
|
372
|
+
return {
|
|
373
|
+
setupToken: tokenState.accessToken,
|
|
374
|
+
refreshToken: tokenState.refreshToken,
|
|
375
|
+
expiresAt: tokenState.expiresAt,
|
|
376
|
+
};
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
catch {
|
|
380
|
+
// Exchange failed — use the raw setup token as-is (it'll work until expiry)
|
|
381
|
+
}
|
|
382
|
+
/* v8 ignore stop */
|
|
383
|
+
return { setupToken };
|
|
384
|
+
}
|
|
385
|
+
// Generic prompt-for-fields fallback (minimax, azure, any future simple providers)
|
|
386
|
+
const prompt = ensurePromptInput(input.promptInput, input.provider);
|
|
387
|
+
const desc = identity_1.PROVIDER_CREDENTIALS[input.provider];
|
|
388
|
+
const creds = {};
|
|
389
|
+
for (const field of desc.required) {
|
|
390
|
+
/* v8 ignore next -- fallback: all current providers define promptLabels for required fields @preserve */
|
|
391
|
+
const label = desc.promptLabels[field] ?? field;
|
|
392
|
+
const value = (await prompt(`${label}: `)).trim();
|
|
393
|
+
if (!value)
|
|
394
|
+
throw new Error(`${label} is required.`);
|
|
395
|
+
creds[field] = value;
|
|
396
|
+
}
|
|
397
|
+
return creds;
|
|
398
|
+
}
|
|
399
|
+
async function resolveHatchCredentials(input) {
|
|
400
|
+
const credentials = { ...(input.credentials ?? {}) };
|
|
401
|
+
// If all required fields are already provided, return as-is
|
|
402
|
+
const cred = credentials;
|
|
403
|
+
const missing = identity_1.PROVIDER_CREDENTIALS[input.provider].required.some((key) => !cred[key]);
|
|
404
|
+
if (!missing)
|
|
405
|
+
return credentials;
|
|
406
|
+
// Try the full auth flow (wraps collectRuntimeAuthCredentials + writes secrets)
|
|
407
|
+
if (input.runAuthFlow) {
|
|
408
|
+
const result = await input.runAuthFlow({
|
|
409
|
+
agentName: input.agentName,
|
|
410
|
+
provider: input.provider,
|
|
411
|
+
promptInput: input.promptInput,
|
|
412
|
+
onProgress: input.onProgress,
|
|
413
|
+
});
|
|
414
|
+
Object.assign(credentials, result.credentials);
|
|
415
|
+
/* v8 ignore next 3 -- branch: auth flow always fills all required fields in production @preserve */
|
|
416
|
+
if (!identity_1.PROVIDER_CREDENTIALS[input.provider].required.some((key) => !credentials[key])) {
|
|
417
|
+
return credentials;
|
|
418
|
+
}
|
|
419
|
+
}
|
|
420
|
+
// Prompt for any still-missing required fields
|
|
421
|
+
/* v8 ignore next -- guard: no promptInput means we can't collect remaining fields @preserve */
|
|
422
|
+
if (input.promptInput) {
|
|
423
|
+
const desc = identity_1.PROVIDER_CREDENTIALS[input.provider];
|
|
424
|
+
for (const field of desc.required) {
|
|
425
|
+
if (!cred[field]) {
|
|
426
|
+
const label = desc.promptLabels[field] ?? field;
|
|
427
|
+
cred[field] = await input.promptInput(`${label}: `);
|
|
428
|
+
}
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
return credentials;
|
|
432
|
+
}
|
|
433
|
+
async function runRuntimeAuthFlow(input, deps = {}) {
|
|
434
|
+
assertPersistentProviderCredentialsAllowed(input.agentName);
|
|
435
|
+
(0, runtime_1.emitNervesEvent)({
|
|
436
|
+
component: "daemon",
|
|
437
|
+
event: "daemon.auth_flow_start",
|
|
438
|
+
message: "starting runtime auth flow",
|
|
439
|
+
meta: { agentName: input.agentName, provider: input.provider },
|
|
440
|
+
});
|
|
441
|
+
writeAuthProgress(input, `checking ${input.agentName}'s vault access...`);
|
|
442
|
+
const vault = await (0, provider_credentials_1.refreshProviderCredentialPool)(input.agentName, {
|
|
443
|
+
providers: [input.provider],
|
|
444
|
+
onProgress: (message) => writeAuthProgress(input, message),
|
|
445
|
+
});
|
|
446
|
+
if (!vault.ok && vault.reason === "unavailable") {
|
|
447
|
+
const fix = (0, vault_unlock_1.isCredentialVaultNotConfiguredError)(vault.error)
|
|
448
|
+
? (0, vault_unlock_1.vaultCreateRecoverFix)(input.agentName, `Then retry 'ouro auth --agent ${input.agentName} --provider ${input.provider}'.`)
|
|
449
|
+
: (0, vault_unlock_1.vaultUnlockReplaceRecoverFix)(input.agentName, `Then retry 'ouro auth --agent ${input.agentName} --provider ${input.provider}'.`);
|
|
450
|
+
throw new Error(`${vault.error}\n${fix}`);
|
|
451
|
+
}
|
|
452
|
+
const credentials = await collectRuntimeAuthCredentials(input, deps);
|
|
453
|
+
let credentialPath;
|
|
454
|
+
try {
|
|
455
|
+
;
|
|
456
|
+
({
|
|
457
|
+
credentialPath,
|
|
458
|
+
} = await storeProviderCredentials(input.agentName, input.provider, credentials, {
|
|
459
|
+
onProgress: (message) => writeAuthProgress(input, message),
|
|
460
|
+
}));
|
|
461
|
+
}
|
|
462
|
+
catch (error) {
|
|
463
|
+
throw formatVaultStoreError(input.agentName, input.provider, error);
|
|
464
|
+
}
|
|
465
|
+
writeAuthProgress(input, `credentials stored at ${credentialPath}; in-memory provider credential pool refreshed.`);
|
|
466
|
+
(0, runtime_1.emitNervesEvent)({
|
|
467
|
+
component: "daemon",
|
|
468
|
+
event: "daemon.auth_flow_end",
|
|
469
|
+
message: "completed runtime auth flow",
|
|
470
|
+
meta: { agentName: input.agentName, provider: input.provider, credentialPath },
|
|
471
|
+
});
|
|
472
|
+
return {
|
|
473
|
+
agentName: input.agentName,
|
|
474
|
+
provider: input.provider,
|
|
475
|
+
credentialPath,
|
|
476
|
+
message: `authenticated ${input.agentName} with ${input.provider}`,
|
|
477
|
+
credentials,
|
|
478
|
+
};
|
|
479
|
+
}
|