@ouro.bot/cli 0.1.0-alpha.56 → 0.1.0-alpha.560
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 +3596 -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 +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/senses/voice/elevenlabs.js +125 -0
- package/dist/senses/voice/index.js +22 -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 +133 -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,330 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Startup TUI — real-time progress display for `ouro up`.
|
|
4
|
+
*
|
|
5
|
+
* Replaces the old `verifyDaemonAlive()` socket poll with a richer system
|
|
6
|
+
* that shows per-agent status, waits for stability, and reports degraded
|
|
7
|
+
* agents with actionable error information.
|
|
8
|
+
*
|
|
9
|
+
* Pure functions (`renderStartupProgress`, `assessStability`) are fully
|
|
10
|
+
* testable. The polling loop (`pollDaemonStartup`) uses dependency injection
|
|
11
|
+
* for all I/O.
|
|
12
|
+
*/
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.assessStability = assessStability;
|
|
15
|
+
exports.renderStartupProgress = renderStartupProgress;
|
|
16
|
+
exports.renderWaitingForDaemon = renderWaitingForDaemon;
|
|
17
|
+
exports.pollDaemonStartup = pollDaemonStartup;
|
|
18
|
+
const cli_render_1 = require("./cli-render");
|
|
19
|
+
const runtime_1 = require("../../nerves/runtime");
|
|
20
|
+
const terminal_ui_1 = require("./terminal-ui");
|
|
21
|
+
// ── Constants ──
|
|
22
|
+
const SPINNER_FRAMES = "⠋⠙⠹⠸⠼⠴⠦⠧⠇⠏";
|
|
23
|
+
const STABILITY_THRESHOLD_MS = 5_000;
|
|
24
|
+
const POLL_INTERVAL_MS = 500;
|
|
25
|
+
const STARTUP_POLL_TIMEOUT_MS = 180_000;
|
|
26
|
+
// ── ANSI helpers ──
|
|
27
|
+
const RESET = "\x1b[0m";
|
|
28
|
+
const BOLD = "\x1b[1m";
|
|
29
|
+
const DIM = "\x1b[2m";
|
|
30
|
+
const GREEN = "\x1b[38;2;46;204;64m";
|
|
31
|
+
const RED = "\x1b[38;2;231;76;60m";
|
|
32
|
+
const YELLOW = "\x1b[38;2;230;190;50m";
|
|
33
|
+
// ── Pure functions ──
|
|
34
|
+
/**
|
|
35
|
+
* Assess whether all workers have reached a terminal state (stable or crashed).
|
|
36
|
+
* A worker is "stable" when status is "running" and it has been running for
|
|
37
|
+
* at least STABILITY_THRESHOLD_MS. A worker is "definitively failed" when
|
|
38
|
+
* status is "crashed". All other states are unresolved.
|
|
39
|
+
*/
|
|
40
|
+
function assessStability(payload, now) {
|
|
41
|
+
const stable = [];
|
|
42
|
+
const degraded = [];
|
|
43
|
+
let allResolved = true;
|
|
44
|
+
for (const worker of payload.workers) {
|
|
45
|
+
if (worker.status === "crashed") {
|
|
46
|
+
degraded.push({
|
|
47
|
+
agent: worker.agent,
|
|
48
|
+
errorReason: worker.errorReason ?? "unknown error",
|
|
49
|
+
fixHint: worker.fixHint ?? "check daemon logs",
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
else if (worker.status === "running" && worker.startedAt !== null) {
|
|
53
|
+
const startedMs = new Date(worker.startedAt).getTime();
|
|
54
|
+
const runningMs = now - startedMs;
|
|
55
|
+
if (runningMs >= STABILITY_THRESHOLD_MS) {
|
|
56
|
+
stable.push(worker.agent);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
allResolved = false;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
// starting, stopped, or running with null startedAt — not yet resolved
|
|
64
|
+
allResolved = false;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return { resolved: allResolved, stable, degraded };
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Build an ANSI string for in-place terminal display during polling.
|
|
71
|
+
* Uses cursor-up and line-clear escapes to overwrite previous output.
|
|
72
|
+
*/
|
|
73
|
+
function renderStartupProgress(payload, elapsed, prevLineCount = 0, options = {}) {
|
|
74
|
+
const isTTY = options.isTTY ?? true;
|
|
75
|
+
const frameIndex = Math.floor(elapsed / 100) % SPINNER_FRAMES.length;
|
|
76
|
+
const spinner = SPINNER_FRAMES[frameIndex];
|
|
77
|
+
const lines = [];
|
|
78
|
+
const elapsedSec = (elapsed / 1000).toFixed(1);
|
|
79
|
+
lines.push(isTTY
|
|
80
|
+
? `${spinner} ${BOLD}waiting for agents${RESET} ${DIM}(${elapsedSec}s)${RESET}`
|
|
81
|
+
: `${spinner} waiting for agents (${elapsedSec}s)`);
|
|
82
|
+
for (const worker of payload.workers) {
|
|
83
|
+
const statusText = isTTY ? colorStatus(worker.status) : worker.status;
|
|
84
|
+
lines.push(` ${worker.agent}/${worker.worker}: ${statusText}`);
|
|
85
|
+
}
|
|
86
|
+
return renderStartupLines(lines, prevLineCount, isTTY);
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Render a pre-socket status line showing what the daemon is doing.
|
|
90
|
+
*/
|
|
91
|
+
function renderWaitingForDaemon(elapsed, latestEvent, prevLineCount = 0, options = {}) {
|
|
92
|
+
const isTTY = options.isTTY ?? true;
|
|
93
|
+
const elapsedSec = (elapsed / 1000).toFixed(1);
|
|
94
|
+
const frameIndex = Math.floor(elapsed / 100) % SPINNER_FRAMES.length;
|
|
95
|
+
const spinner = SPINNER_FRAMES[frameIndex];
|
|
96
|
+
const lines = [];
|
|
97
|
+
lines.push(isTTY
|
|
98
|
+
? `${spinner} ${BOLD}starting background service${RESET} ${DIM}(${elapsedSec}s)${RESET}`
|
|
99
|
+
: `${spinner} starting background service (${elapsedSec}s)`);
|
|
100
|
+
if (latestEvent) {
|
|
101
|
+
const detail = `latest daemon event: ${latestEvent}`;
|
|
102
|
+
lines.push(isTTY ? ` ${DIM}${detail}${RESET}` : ` ${detail}`);
|
|
103
|
+
}
|
|
104
|
+
return renderStartupLines(lines, prevLineCount, isTTY);
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Render the final summary after all agents have resolved.
|
|
108
|
+
*/
|
|
109
|
+
function renderFinalSummary(result, isTTY) {
|
|
110
|
+
const lines = [];
|
|
111
|
+
for (const agent of result.stable) {
|
|
112
|
+
lines.push(isTTY ? ` ${GREEN}\u2713${RESET} ${agent}: ${GREEN}stable${RESET}` : ` \u2713 ${agent}: stable`);
|
|
113
|
+
}
|
|
114
|
+
for (const d of result.degraded) {
|
|
115
|
+
lines.push(isTTY ? ` ${RED}\u2717${RESET} ${d.agent}: ${RED}degraded${RESET}` : ` \u2717 ${d.agent}: degraded`);
|
|
116
|
+
if (d.errorReason !== "unknown error") {
|
|
117
|
+
lines.push(isTTY ? ` ${DIM}error: ${d.errorReason}${RESET}` : ` error: ${d.errorReason}`);
|
|
118
|
+
}
|
|
119
|
+
if (d.fixHint !== "check daemon logs") {
|
|
120
|
+
lines.push(isTTY ? ` ${DIM}fix: ${d.fixHint}${RESET}` : ` fix: ${d.fixHint}`);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (!isTTY)
|
|
124
|
+
return lines.join("\n") + "\n";
|
|
125
|
+
return lines.map((line) => `\x1b[2K${line}`).join("\n") + "\n";
|
|
126
|
+
}
|
|
127
|
+
// ── Polling loop ──
|
|
128
|
+
/**
|
|
129
|
+
* Poll the daemon's status socket until all agents are stable or definitively
|
|
130
|
+
* failed, rendering real-time progress to the terminal.
|
|
131
|
+
*
|
|
132
|
+
* Detects daemon process death: if the spawned PID is no longer alive and the
|
|
133
|
+
* socket never came up, reports the failure immediately instead of spinning.
|
|
134
|
+
*/
|
|
135
|
+
async function pollDaemonStartup(deps) {
|
|
136
|
+
const startTime = deps.now();
|
|
137
|
+
const maxWaitMs = deps.maxWaitMs ?? STARTUP_POLL_TIMEOUT_MS;
|
|
138
|
+
let prevLineCount = 0;
|
|
139
|
+
const isTTY = deps.isTTY ?? true;
|
|
140
|
+
const isAlive = deps.isProcessAlive ?? defaultIsProcessAlive;
|
|
141
|
+
const shouldRender = deps.render ?? true;
|
|
142
|
+
let lastProgress = null;
|
|
143
|
+
const reportProgress = (message) => {
|
|
144
|
+
if (!deps.onProgress || message === lastProgress)
|
|
145
|
+
return;
|
|
146
|
+
lastProgress = message;
|
|
147
|
+
deps.onProgress(message);
|
|
148
|
+
};
|
|
149
|
+
(0, runtime_1.emitNervesEvent)({
|
|
150
|
+
component: "daemon",
|
|
151
|
+
event: "daemon.startup_poll_start",
|
|
152
|
+
message: "beginning startup stability polling",
|
|
153
|
+
meta: { socketPath: deps.socketPath, daemonPid: deps.daemonPid },
|
|
154
|
+
});
|
|
155
|
+
while (true) {
|
|
156
|
+
const now = deps.now();
|
|
157
|
+
const elapsed = now - startTime;
|
|
158
|
+
let payload = null;
|
|
159
|
+
try {
|
|
160
|
+
const response = await deps.sendCommand(deps.socketPath, { kind: "daemon.status" });
|
|
161
|
+
payload = (0, cli_render_1.parseStatusPayload)(response.data);
|
|
162
|
+
}
|
|
163
|
+
catch {
|
|
164
|
+
// Socket not yet available — check if the daemon process is still alive
|
|
165
|
+
if (deps.daemonPid !== null && !isAlive(deps.daemonPid)) {
|
|
166
|
+
const latestEvent = deps.readLatestDaemonEvent?.() ?? null;
|
|
167
|
+
const errorMsg = latestEvent ?? "daemon process died during startup";
|
|
168
|
+
(0, runtime_1.emitNervesEvent)({
|
|
169
|
+
level: "error",
|
|
170
|
+
component: "daemon",
|
|
171
|
+
event: "daemon.startup_process_died",
|
|
172
|
+
message: "daemon process died before socket came up",
|
|
173
|
+
meta: { pid: deps.daemonPid, lastEvent: latestEvent },
|
|
174
|
+
});
|
|
175
|
+
// Clear the waiting line
|
|
176
|
+
if (isTTY && prevLineCount > 0) {
|
|
177
|
+
let clear = `\x1b[${prevLineCount}A`;
|
|
178
|
+
for (let i = 0; i < prevLineCount; i++)
|
|
179
|
+
clear += `\x1b[2K\n`;
|
|
180
|
+
deps.writeRaw(clear);
|
|
181
|
+
}
|
|
182
|
+
return {
|
|
183
|
+
stable: [],
|
|
184
|
+
degraded: [{ agent: "daemon", errorReason: errorMsg, fixHint: "check daemon logs or run `ouro doctor`" }],
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
const latestEvent = deps.readLatestDaemonEvent?.() ?? null;
|
|
188
|
+
if (elapsed >= maxWaitMs) {
|
|
189
|
+
const errorMsg = latestEvent
|
|
190
|
+
? `daemon did not answer within ${(maxWaitMs / 1000).toFixed(0)}s; latest event: ${latestEvent}`
|
|
191
|
+
: `daemon did not answer within ${(maxWaitMs / 1000).toFixed(0)}s`;
|
|
192
|
+
const result = {
|
|
193
|
+
stable: [],
|
|
194
|
+
degraded: [{ agent: "daemon", errorReason: errorMsg, fixHint: "check daemon logs or run `ouro doctor`" }],
|
|
195
|
+
};
|
|
196
|
+
if (shouldRender) {
|
|
197
|
+
const summary = renderFinalSummary(result, isTTY);
|
|
198
|
+
deps.writeRaw(summary);
|
|
199
|
+
}
|
|
200
|
+
(0, runtime_1.emitNervesEvent)({
|
|
201
|
+
level: "error",
|
|
202
|
+
component: "daemon",
|
|
203
|
+
event: "daemon.startup_poll_timeout",
|
|
204
|
+
message: "daemon startup polling timed out before the daemon answered",
|
|
205
|
+
meta: { socketPath: deps.socketPath, daemonPid: deps.daemonPid, elapsedMs: elapsed, maxWaitMs, lastEvent: latestEvent },
|
|
206
|
+
});
|
|
207
|
+
return result;
|
|
208
|
+
}
|
|
209
|
+
// Show what the daemon is doing from its log
|
|
210
|
+
reportProgress([
|
|
211
|
+
"waiting for Ouro to answer",
|
|
212
|
+
latestEvent ? `- latest daemon event: ${latestEvent}` : "- background service is still starting",
|
|
213
|
+
].join("\n"));
|
|
214
|
+
if (shouldRender) {
|
|
215
|
+
const output = renderWaitingForDaemon(elapsed, latestEvent, prevLineCount, { isTTY });
|
|
216
|
+
deps.writeRaw(output);
|
|
217
|
+
prevLineCount = latestEvent ? 2 : 1;
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
if (payload) {
|
|
221
|
+
reportProgress(formatStartupProgressDetail(payload));
|
|
222
|
+
if (shouldRender) {
|
|
223
|
+
const output = renderStartupProgress(payload, elapsed, prevLineCount, { isTTY });
|
|
224
|
+
deps.writeRaw(output);
|
|
225
|
+
prevLineCount = payload.workers.length + 1;
|
|
226
|
+
}
|
|
227
|
+
const assessment = assessStability(payload, now);
|
|
228
|
+
if (assessment.resolved) {
|
|
229
|
+
const result = {
|
|
230
|
+
stable: assessment.stable,
|
|
231
|
+
degraded: assessment.degraded,
|
|
232
|
+
};
|
|
233
|
+
if (shouldRender) {
|
|
234
|
+
const summary = renderFinalSummary(result, isTTY);
|
|
235
|
+
deps.writeRaw(summary);
|
|
236
|
+
}
|
|
237
|
+
(0, runtime_1.emitNervesEvent)({
|
|
238
|
+
component: "daemon",
|
|
239
|
+
event: "daemon.startup_poll_end",
|
|
240
|
+
message: "startup polling complete",
|
|
241
|
+
meta: {
|
|
242
|
+
stableCount: result.stable.length,
|
|
243
|
+
degradedCount: result.degraded.length,
|
|
244
|
+
elapsedMs: elapsed,
|
|
245
|
+
},
|
|
246
|
+
});
|
|
247
|
+
return result;
|
|
248
|
+
}
|
|
249
|
+
if (elapsed >= maxWaitMs) {
|
|
250
|
+
const result = buildTimedOutStartupResult(payload, assessment, maxWaitMs);
|
|
251
|
+
if (shouldRender) {
|
|
252
|
+
const summary = renderFinalSummary(result, isTTY);
|
|
253
|
+
deps.writeRaw(summary);
|
|
254
|
+
}
|
|
255
|
+
(0, runtime_1.emitNervesEvent)({
|
|
256
|
+
level: "error",
|
|
257
|
+
component: "daemon",
|
|
258
|
+
event: "daemon.startup_poll_timeout",
|
|
259
|
+
message: "daemon startup polling timed out with unresolved workers",
|
|
260
|
+
meta: {
|
|
261
|
+
socketPath: deps.socketPath,
|
|
262
|
+
daemonPid: deps.daemonPid,
|
|
263
|
+
elapsedMs: elapsed,
|
|
264
|
+
maxWaitMs,
|
|
265
|
+
stableCount: result.stable.length,
|
|
266
|
+
degradedCount: result.degraded.length,
|
|
267
|
+
},
|
|
268
|
+
});
|
|
269
|
+
return result;
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
await deps.sleep(POLL_INTERVAL_MS);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
function buildTimedOutStartupResult(payload, assessment, maxWaitMs) {
|
|
276
|
+
const stable = [...assessment.stable];
|
|
277
|
+
const degraded = [...assessment.degraded];
|
|
278
|
+
const stableAgents = new Set(stable);
|
|
279
|
+
const degradedAgents = new Set();
|
|
280
|
+
for (const worker of degraded)
|
|
281
|
+
degradedAgents.add(worker.agent);
|
|
282
|
+
const seconds = (maxWaitMs / 1000).toFixed(0);
|
|
283
|
+
for (const worker of payload.workers) {
|
|
284
|
+
if (stableAgents.has(worker.agent) || degradedAgents.has(worker.agent))
|
|
285
|
+
continue;
|
|
286
|
+
degraded.push({
|
|
287
|
+
agent: worker.agent,
|
|
288
|
+
errorReason: `startup timed out after ${seconds}s while worker was ${worker.status}`,
|
|
289
|
+
fixHint: worker.errorReason
|
|
290
|
+
? worker.fixHint ?? "check daemon logs"
|
|
291
|
+
: "run `ouro status` or `ouro doctor` for current worker details; the daemon is still answering",
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
return { stable, degraded };
|
|
295
|
+
}
|
|
296
|
+
function formatStartupWorkerLine(payload) {
|
|
297
|
+
const base = `- ${payload.agent}/${payload.worker}: ${payload.status}`;
|
|
298
|
+
if (payload.status === "crashed" && payload.errorReason) {
|
|
299
|
+
return `${base} (${payload.errorReason})`;
|
|
300
|
+
}
|
|
301
|
+
return base;
|
|
302
|
+
}
|
|
303
|
+
function formatStartupProgressDetail(payload) {
|
|
304
|
+
if (payload.workers.length === 0)
|
|
305
|
+
return "Ouro answered";
|
|
306
|
+
return [
|
|
307
|
+
"Ouro answered",
|
|
308
|
+
...payload.workers.map((worker) => formatStartupWorkerLine(worker)),
|
|
309
|
+
].join("\n");
|
|
310
|
+
}
|
|
311
|
+
function colorStatus(status) {
|
|
312
|
+
const statusColor = status === "running" ? GREEN
|
|
313
|
+
: status === "crashed" ? RED
|
|
314
|
+
: YELLOW;
|
|
315
|
+
return `${statusColor}${status}${RESET}`;
|
|
316
|
+
}
|
|
317
|
+
function renderStartupLines(lines, prevLineCount, isTTY) {
|
|
318
|
+
return (0, terminal_ui_1.renderOverwriteFrame)(lines, prevLineCount, isTTY);
|
|
319
|
+
}
|
|
320
|
+
/* v8 ignore start -- process liveness check: uses real process.kill(0), tested via deployment @preserve */
|
|
321
|
+
function defaultIsProcessAlive(pid) {
|
|
322
|
+
try {
|
|
323
|
+
process.kill(pid, 0);
|
|
324
|
+
return true;
|
|
325
|
+
}
|
|
326
|
+
catch {
|
|
327
|
+
return false;
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
/* v8 ignore stop */
|
|
@@ -39,6 +39,7 @@ const path = __importStar(require("path"));
|
|
|
39
39
|
const identity_1 = require("../identity");
|
|
40
40
|
const runtime_1 = require("../../nerves/runtime");
|
|
41
41
|
const parser_1 = require("../../repertoire/tasks/parser");
|
|
42
|
+
const cadence_1 = require("./cadence");
|
|
42
43
|
function walkMarkdownFiles(root, readdirSync, existsSync, files) {
|
|
43
44
|
if (!existsSync(root))
|
|
44
45
|
return;
|
|
@@ -53,29 +54,6 @@ function walkMarkdownFiles(root, readdirSync, existsSync, files) {
|
|
|
53
54
|
}
|
|
54
55
|
}
|
|
55
56
|
}
|
|
56
|
-
function parseCadence(raw) {
|
|
57
|
-
if (typeof raw !== "string")
|
|
58
|
-
return null;
|
|
59
|
-
const value = raw.trim();
|
|
60
|
-
if (!value)
|
|
61
|
-
return null;
|
|
62
|
-
// Cron format (minute hour day month weekday)
|
|
63
|
-
if (/^\S+\s+\S+\s+\S+\s+\S+\s+\S+$/.test(value)) {
|
|
64
|
-
return value;
|
|
65
|
-
}
|
|
66
|
-
const cadenceMatch = /^(\d+)(m|h|d)$/.exec(value);
|
|
67
|
-
if (!cadenceMatch)
|
|
68
|
-
return null;
|
|
69
|
-
const interval = Number.parseInt(cadenceMatch[1], 10);
|
|
70
|
-
if (!Number.isFinite(interval) || interval <= 0)
|
|
71
|
-
return null;
|
|
72
|
-
const unit = cadenceMatch[2];
|
|
73
|
-
if (unit === "m")
|
|
74
|
-
return `*/${interval} * * * *`;
|
|
75
|
-
if (unit === "h")
|
|
76
|
-
return `0 */${interval} * * *`;
|
|
77
|
-
return `0 0 */${interval} * *`;
|
|
78
|
-
}
|
|
79
57
|
function parseScheduledAt(raw) {
|
|
80
58
|
if (typeof raw !== "string")
|
|
81
59
|
return null;
|
|
@@ -140,7 +118,7 @@ class TaskDrivenScheduler {
|
|
|
140
118
|
const nextTaskPaths = new Map();
|
|
141
119
|
for (const agent of this.agents) {
|
|
142
120
|
const taskRoot = path.join(this.bundlesRoot, `${agent}.ouro`, "tasks");
|
|
143
|
-
const collections = ["one-shots", "ongoing"
|
|
121
|
+
const collections = ["one-shots", "ongoing"];
|
|
144
122
|
const files = [];
|
|
145
123
|
for (const collection of collections) {
|
|
146
124
|
walkMarkdownFiles(path.join(taskRoot, collection), this.readdirSync, this.existsSync, files);
|
|
@@ -157,7 +135,7 @@ class TaskDrivenScheduler {
|
|
|
157
135
|
nextTaskPaths.set(`${agent}:${taskId}`, filePath);
|
|
158
136
|
if (task.status === "done")
|
|
159
137
|
continue;
|
|
160
|
-
const cadence =
|
|
138
|
+
const cadence = (0, cadence_1.parseCadenceToCron)(task.frontmatter.cadence);
|
|
161
139
|
if (cadence) {
|
|
162
140
|
const id = `${agent}:${taskId}:cadence`;
|
|
163
141
|
nextJobs.set(id, {
|