@ouro.bot/cli 0.1.0-alpha.55 → 0.1.0-alpha.550
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 +3555 -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 +758 -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
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.findActivePersistentObligation = findActivePersistentObligation;
|
|
4
|
+
exports.findStatusObligation = findStatusObligation;
|
|
5
|
+
exports.renderActiveObligationSteering = renderActiveObligationSteering;
|
|
6
|
+
exports.renderConcreteStatusGuidance = renderConcreteStatusGuidance;
|
|
7
|
+
exports.renderLiveThreadStatusShape = renderLiveThreadStatusShape;
|
|
8
|
+
exports.buildExactStatusReply = buildExactStatusReply;
|
|
9
|
+
exports.renderExactStatusReplyContract = renderExactStatusReplyContract;
|
|
10
|
+
const config_1 = require("../heart/config");
|
|
11
|
+
const active_work_1 = require("../heart/active-work");
|
|
12
|
+
const runtime_1 = require("../nerves/runtime");
|
|
13
|
+
function findActivePersistentObligation(frame) {
|
|
14
|
+
if (!frame)
|
|
15
|
+
return null;
|
|
16
|
+
return (frame.pendingObligations ?? []).find((ob) => ob.status !== "pending" && ob.status !== "fulfilled") ?? null;
|
|
17
|
+
}
|
|
18
|
+
function obligationTimestampMs(obligation) {
|
|
19
|
+
return Date.parse(obligation.updatedAt ?? obligation.createdAt);
|
|
20
|
+
}
|
|
21
|
+
function newestObligationFirst(left, right) {
|
|
22
|
+
return obligationTimestampMs(right) - obligationTimestampMs(left);
|
|
23
|
+
}
|
|
24
|
+
function matchesCurrentSession(frame, obligation) {
|
|
25
|
+
return matchesSessionOrigin(frame, obligation.origin);
|
|
26
|
+
}
|
|
27
|
+
function matchesSessionOrigin(frame, origin) {
|
|
28
|
+
return Boolean(frame.currentSession
|
|
29
|
+
&& origin.friendId === frame.currentSession.friendId
|
|
30
|
+
&& origin.channel === frame.currentSession.channel
|
|
31
|
+
&& (0, config_1.sanitizeKey)(origin.key) === (0, config_1.sanitizeKey)(frame.currentSession.key));
|
|
32
|
+
}
|
|
33
|
+
function findStatusObligation(frame) {
|
|
34
|
+
if (!frame)
|
|
35
|
+
return null;
|
|
36
|
+
const openObligations = [...(frame.pendingObligations ?? [])]
|
|
37
|
+
.filter((obligation) => obligation.status !== "fulfilled")
|
|
38
|
+
.sort(newestObligationFirst);
|
|
39
|
+
const sameSession = openObligations.find((obligation) => matchesCurrentSession(frame, obligation));
|
|
40
|
+
if (sameSession)
|
|
41
|
+
return sameSession;
|
|
42
|
+
return openObligations[0] ?? null;
|
|
43
|
+
}
|
|
44
|
+
function findCurrentSessionStatusObligation(frame) {
|
|
45
|
+
const openObligations = [...(frame.pendingObligations ?? [])]
|
|
46
|
+
.filter((obligation) => obligation.status !== "fulfilled")
|
|
47
|
+
.sort(newestObligationFirst);
|
|
48
|
+
return openObligations.find((obligation) => matchesCurrentSession(frame, obligation)) ?? null;
|
|
49
|
+
}
|
|
50
|
+
function renderActiveObligationSteering(obligation) {
|
|
51
|
+
(0, runtime_1.emitNervesEvent)({
|
|
52
|
+
component: "mind",
|
|
53
|
+
event: "mind.obligation_steering_rendered",
|
|
54
|
+
message: "rendered active obligation steering",
|
|
55
|
+
meta: {
|
|
56
|
+
hasObligation: Boolean(obligation),
|
|
57
|
+
hasSurface: Boolean(obligation?.currentSurface?.label),
|
|
58
|
+
},
|
|
59
|
+
});
|
|
60
|
+
if (!obligation)
|
|
61
|
+
return "";
|
|
62
|
+
const name = obligation.origin.friendId;
|
|
63
|
+
const surfaceLine = obligation.currentSurface?.label
|
|
64
|
+
? `\nright now that work is happening in ${obligation.currentSurface.label}.`
|
|
65
|
+
: "";
|
|
66
|
+
return `## where my attention is
|
|
67
|
+
i'm already working on something i owe ${name}.${surfaceLine}
|
|
68
|
+
|
|
69
|
+
i should close that loop before i act like this is a fresh blank turn.`;
|
|
70
|
+
}
|
|
71
|
+
function mergeArtifactFallback(obligation) {
|
|
72
|
+
const trimmed = obligation.content.trim();
|
|
73
|
+
if (!trimmed)
|
|
74
|
+
return "the fix";
|
|
75
|
+
const stripped = trimmed.replace(/^merge(?:\s+|$)/i, "").trim();
|
|
76
|
+
return stripped || "the fix";
|
|
77
|
+
}
|
|
78
|
+
function formatMergeArtifact(obligation) {
|
|
79
|
+
const currentArtifact = obligation.currentArtifact?.trim();
|
|
80
|
+
if (currentArtifact)
|
|
81
|
+
return currentArtifact;
|
|
82
|
+
if (obligation.currentSurface?.kind === "merge") {
|
|
83
|
+
const surfaceLabel = obligation.currentSurface.label.trim();
|
|
84
|
+
if (surfaceLabel)
|
|
85
|
+
return surfaceLabel;
|
|
86
|
+
}
|
|
87
|
+
return mergeArtifactFallback(obligation);
|
|
88
|
+
}
|
|
89
|
+
function formatActiveLane(frame, obligation) {
|
|
90
|
+
const liveCodingSession = frame.codingSessions?.[0];
|
|
91
|
+
if (liveCodingSession) {
|
|
92
|
+
const sameThread = frame.currentSession
|
|
93
|
+
&& liveCodingSession.originSession
|
|
94
|
+
&& liveCodingSession.originSession.friendId === frame.currentSession.friendId
|
|
95
|
+
&& liveCodingSession.originSession.channel === frame.currentSession.channel
|
|
96
|
+
&& liveCodingSession.originSession.key === frame.currentSession.key;
|
|
97
|
+
return sameThread
|
|
98
|
+
? `${liveCodingSession.runner} ${liveCodingSession.id} for this same thread`
|
|
99
|
+
: liveCodingSession.originSession
|
|
100
|
+
? `${liveCodingSession.runner} ${liveCodingSession.id} for ${liveCodingSession.originSession.channel}/${liveCodingSession.originSession.key}`
|
|
101
|
+
: `${liveCodingSession.runner} ${liveCodingSession.id}`;
|
|
102
|
+
}
|
|
103
|
+
return obligation.currentSurface?.label
|
|
104
|
+
|| (matchesCurrentSession(frame, obligation) ? "this same thread" : "this live loop");
|
|
105
|
+
}
|
|
106
|
+
function formatCurrentArtifact(frame, obligation) {
|
|
107
|
+
if (obligation?.currentArtifact)
|
|
108
|
+
return obligation.currentArtifact;
|
|
109
|
+
if (obligation?.currentSurface?.kind === "merge")
|
|
110
|
+
return obligation.currentSurface.label;
|
|
111
|
+
if ((frame.codingSessions ?? []).length > 0)
|
|
112
|
+
return "no PR or merge artifact yet";
|
|
113
|
+
return obligation ? "no artifact yet" : "";
|
|
114
|
+
}
|
|
115
|
+
function formatNextAction(frame, obligation) {
|
|
116
|
+
const obligationHasConcreteArtifact = Boolean(obligation?.currentArtifact?.trim())
|
|
117
|
+
|| obligation?.currentSurface?.kind === "merge";
|
|
118
|
+
if (obligation?.status === "waiting_for_merge") {
|
|
119
|
+
return obligation.nextAction?.trim() || `wait for checks, merge ${formatMergeArtifact(obligation)}, then update runtime`;
|
|
120
|
+
}
|
|
121
|
+
if (obligation?.status === "updating_runtime") {
|
|
122
|
+
return obligation.nextAction?.trim() || "update runtime, verify version/changelog, then re-observe";
|
|
123
|
+
}
|
|
124
|
+
if (obligationHasConcreteArtifact && obligation?.nextAction?.trim()) {
|
|
125
|
+
return obligation.nextAction.trim();
|
|
126
|
+
}
|
|
127
|
+
const liveCodingSession = frame.codingSessions?.[0];
|
|
128
|
+
if (liveCodingSession?.status === "waiting_input") {
|
|
129
|
+
return `answer ${liveCodingSession.runner} ${liveCodingSession.id} and continue`;
|
|
130
|
+
}
|
|
131
|
+
if (liveCodingSession?.status === "stalled") {
|
|
132
|
+
return `unstick ${liveCodingSession.runner} ${liveCodingSession.id} and continue`;
|
|
133
|
+
}
|
|
134
|
+
if (liveCodingSession) {
|
|
135
|
+
return "finish the coding pass and bring the result back here";
|
|
136
|
+
}
|
|
137
|
+
if (obligation?.nextAction?.trim())
|
|
138
|
+
return obligation.nextAction.trim();
|
|
139
|
+
if (obligation?.content?.trim()) {
|
|
140
|
+
return `work on "${obligation.content.trim()}" and bring back a concrete artifact`;
|
|
141
|
+
}
|
|
142
|
+
return obligation ? "continue the active loop and bring the result back here" : "";
|
|
143
|
+
}
|
|
144
|
+
function renderConcreteStatusGuidance(frame, obligation) {
|
|
145
|
+
const activeLane = obligation ? formatActiveLane(frame, obligation) : "";
|
|
146
|
+
const currentArtifact = formatCurrentArtifact(frame, obligation);
|
|
147
|
+
const nextAction = formatNextAction(frame, obligation);
|
|
148
|
+
const liveConversation = frame.currentSession
|
|
149
|
+
? `${frame.currentSession.channel}/${frame.currentSession.key}`
|
|
150
|
+
: "";
|
|
151
|
+
if (!activeLane && !currentArtifact && !nextAction)
|
|
152
|
+
return "";
|
|
153
|
+
return `if someone asks what i'm doing or for status mid-task, i answer from these live facts instead of copying a canned block.
|
|
154
|
+
the live conversation is ${liveConversation || "not in a live conversation"}.
|
|
155
|
+
the active lane is ${activeLane}.
|
|
156
|
+
the current artifact is ${currentArtifact}.
|
|
157
|
+
if i just finished or verified something concrete in this live lane, i name that as the latest checkpoint.
|
|
158
|
+
the next action is ${nextAction}.
|
|
159
|
+
|
|
160
|
+
i answer naturally from those facts instead of forcing a canned status block.`;
|
|
161
|
+
}
|
|
162
|
+
function renderLiveThreadStatusShape(frame) {
|
|
163
|
+
if (!frame.currentSession)
|
|
164
|
+
return "";
|
|
165
|
+
return `if someone asks what i'm doing or for status mid-task in this live thread, i answer in these exact lines, in order, with no intro paragraph:
|
|
166
|
+
live conversation: ${frame.currentSession.channel}/${frame.currentSession.key}
|
|
167
|
+
active lane: this same thread
|
|
168
|
+
current artifact: <actual artifact or "no artifact yet">
|
|
169
|
+
latest checkpoint: <freshest concrete thing i just finished or verified>
|
|
170
|
+
next action: <smallest concrete next step i'm taking now>
|
|
171
|
+
|
|
172
|
+
no recap paragraph before those lines.
|
|
173
|
+
no option list.
|
|
174
|
+
present tense only.
|
|
175
|
+
if a finished step matters, i label it "just finished" instead of presenting it as current work.`;
|
|
176
|
+
}
|
|
177
|
+
function buildExactStatusReply(frame, obligation, latestCheckpoint, statusCheckScope) {
|
|
178
|
+
const headerObligation = statusCheckScope === "all-sessions-family"
|
|
179
|
+
? findCurrentSessionStatusObligation(frame)
|
|
180
|
+
: obligation;
|
|
181
|
+
const liveConversation = frame.currentSession
|
|
182
|
+
? `${frame.currentSession.channel}/${frame.currentSession.key}`
|
|
183
|
+
: "not in a live conversation";
|
|
184
|
+
const activeLane = headerObligation
|
|
185
|
+
? formatActiveLane(frame, headerObligation)
|
|
186
|
+
: (frame.currentSession ? "this same thread" : "this live loop");
|
|
187
|
+
const currentArtifact = formatCurrentArtifact(frame, headerObligation) || "no artifact yet";
|
|
188
|
+
const nextAction = formatNextAction(frame, headerObligation) || "continue the active loop and bring the result back here";
|
|
189
|
+
const latest = latestCheckpoint.trim() || "<freshest concrete thing i just finished or verified>";
|
|
190
|
+
const lines = [
|
|
191
|
+
`live conversation: ${liveConversation}`,
|
|
192
|
+
`active lane: ${activeLane}`,
|
|
193
|
+
`current artifact: ${currentArtifact}`,
|
|
194
|
+
`latest checkpoint: ${latest}`,
|
|
195
|
+
`next action: ${nextAction}`,
|
|
196
|
+
];
|
|
197
|
+
if (statusCheckScope === "all-sessions-family") {
|
|
198
|
+
lines.push("other active sessions:");
|
|
199
|
+
const summaries = (0, active_work_1.formatOtherActiveSessionSummaries)(frame);
|
|
200
|
+
lines.push(...(summaries.length > 0 ? summaries : ["- none"]));
|
|
201
|
+
}
|
|
202
|
+
return lines.join("\n");
|
|
203
|
+
}
|
|
204
|
+
function renderExactStatusReplyContract(frame, obligation, statusCheckScope) {
|
|
205
|
+
const headerObligation = statusCheckScope === "all-sessions-family"
|
|
206
|
+
? findCurrentSessionStatusObligation(frame)
|
|
207
|
+
: obligation;
|
|
208
|
+
if (statusCheckScope === "all-sessions-family") {
|
|
209
|
+
return `reply using exactly this status shape and nothing else:
|
|
210
|
+
live conversation: ${frame.currentSession ? `${frame.currentSession.channel}/${frame.currentSession.key}` : "not in a live conversation"}
|
|
211
|
+
active lane: ${headerObligation ? formatActiveLane(frame, headerObligation) : (frame.currentSession ? "this same thread" : "this live loop")}
|
|
212
|
+
current artifact: ${formatCurrentArtifact(frame, headerObligation) || "no artifact yet"}
|
|
213
|
+
latest checkpoint: <freshest concrete thing i just finished or verified>
|
|
214
|
+
next action: ${formatNextAction(frame, headerObligation) || "continue the active loop and bring the result back here"}
|
|
215
|
+
other active sessions:
|
|
216
|
+
- <session label>: <what i'm doing there right now>`;
|
|
217
|
+
}
|
|
218
|
+
return `reply using exactly these five lines and nothing else:
|
|
219
|
+
${buildExactStatusReply(frame, obligation, "<freshest concrete thing i just finished or verified>")}
|
|
220
|
+
`;
|
|
221
|
+
}
|
package/dist/mind/pending.js
CHANGED
|
@@ -38,6 +38,7 @@ exports.getPendingDir = getPendingDir;
|
|
|
38
38
|
exports.getDeferredReturnDir = getDeferredReturnDir;
|
|
39
39
|
exports.getInnerDialogPendingDir = getInnerDialogPendingDir;
|
|
40
40
|
exports.hasPendingMessages = hasPendingMessages;
|
|
41
|
+
exports.queuePendingMessage = queuePendingMessage;
|
|
41
42
|
exports.enqueueDeferredReturn = enqueueDeferredReturn;
|
|
42
43
|
exports.drainDeferredReturns = drainDeferredReturns;
|
|
43
44
|
exports.drainPending = drainPending;
|
|
@@ -74,6 +75,9 @@ function writeQueueFile(queueDir, message) {
|
|
|
74
75
|
fs.writeFileSync(filePath, JSON.stringify(message, null, 2));
|
|
75
76
|
return filePath;
|
|
76
77
|
}
|
|
78
|
+
function queuePendingMessage(pendingDir, message) {
|
|
79
|
+
writeQueueFile(pendingDir, message);
|
|
80
|
+
}
|
|
77
81
|
function drainQueue(queueDir) {
|
|
78
82
|
if (!fs.existsSync(queueDir))
|
|
79
83
|
return { messages: [], recovered: 0 };
|
|
@@ -5,11 +5,12 @@ const prompt_1 = require("./prompt");
|
|
|
5
5
|
const runtime_1 = require("../nerves/runtime");
|
|
6
6
|
async function refreshSystemPrompt(messages, channel, options, context) {
|
|
7
7
|
const newSystem = await (0, prompt_1.buildSystem)(channel, options, context);
|
|
8
|
+
const flattened = (0, prompt_1.flattenSystemPrompt)(newSystem);
|
|
8
9
|
if (messages.length > 0 && messages[0].role === "system") {
|
|
9
|
-
messages[0] = { role: "system", content:
|
|
10
|
+
messages[0] = { role: "system", content: flattened };
|
|
10
11
|
}
|
|
11
12
|
else {
|
|
12
|
-
messages.unshift({ role: "system", content:
|
|
13
|
+
messages.unshift({ role: "system", content: flattened });
|
|
13
14
|
}
|
|
14
15
|
(0, runtime_1.emitNervesEvent)({
|
|
15
16
|
event: "mind.system_prompt_refreshed",
|